我怎么能写一个正则表达式,只匹配字母?
当前回答
Java:
String s= "abcdef";
if(s.matches("[a-zA-Z]+")){
System.out.println("string only contains letters");
}
其他回答
pattern = /[a-zA-Z]/
输入“[a-zA-Z]: #{模式。match("mine blossom")}"好的
[a-zA-Z]: #{pattern.match("456")}"
[a-zA-Z]: #{pattern.match("")}"
输入"[a-zA-Z]: #{pattern.match("#$%^&*")}"
把“[a-zA-Z]: # {pattern.match (" # $ % ^ & * ")}" 好吧
对于PHP,下面的代码就可以了
'/^[a-zA-Z]+$/'
Pattern pattern = Pattern.compile("^[a-zA-Z]+$");
if (pattern.matcher("a").find()) {
...do something ......
}
你可以用
/[a-z]/gi
[]——检查给定输入之间的任何字符
A-z,涵盖了整个字母表
G -----在整个字符串中
我-----得到大写和小写
在python中,我发现了以下工作:
[^\W\d_]
这是因为我们正在创建一个新的字符类([]),它从类\W中排除(^)任何字符(所有不在[a- za - z0 -9_]中的字符),也排除任何数字(\d),也排除下划线(_)。
也就是说,我们已经取了字符类[a-zA-Z0-9_],并删除了0-9和_位。你可能会问,这样写[a-zA-Z]不是比[^\W\d_]更简单吗?如果只处理ASCII文本,您将是正确的,但当处理unicode文本时:
\ W 匹配任何非单词字符的字符。这是\w的反义词。>如果使用了ASCII标志,它就相当于[^a-zA-Z0-9_]。
^来自python re模块文档
也就是说,我们取unicode中所有被认为是单词字符的字符,删除unicode中所有被认为是数字字符的字符,并删除下划线。
例如,下面的代码片段
import re
regex = "[^\W\d_]"
test_string = "A;,./>>?()*)&^*&^%&^#Bsfa1 203974"
re.findall(regex, test_string)
返回
['A', 'B', 's', 'f', 'a']
推荐文章
- 如何从JavaScript中使用正则表达式的字符串中剥离所有标点符号?
- 正则表达式中的单词边界是什么?
- 如何将一个标题转换为jQuery的URL段塞?
- Javascript和regex:分割字符串并保留分隔符
- (grep)正则表达式匹配非ascii字符?
- 如何在保持原始字符串的同时对字符串执行Perl替换?
- 创建正则表达式匹配数组
- *的区别是什么?和。*正则表达式?
- 如何将“camelCase”转换为“Camel Case”?
- 在Java中使用正则表达式提取值
- Java中的正则表达式命名组
- 使用正则表达式搜索和替换Visual Studio代码
- 使用split("|")按管道符号拆分Java字符串
- 替换字符串中第一次出现的模式
- “\d”在正则表达式中是数字吗?