我怎么能写一个正则表达式,只匹配字母?


当前回答

只需使用\w或[:alpha:]即可。它是一个转义序列,只匹配可能出现在单词中的符号。

其他回答

使用字符组

\D

匹配除数字0-9以外的任何字符

^\D+$

参见这里的例子

Pattern pattern = Pattern.compile("^[a-zA-Z]+$");

if (pattern.matcher("a").find()) {

   ...do something ......
}

你可以试试这个正则表达式:[^\W\d_]或[a-zA-Z]。

使用字符集:[a- za -z]匹配a-z中的一个小写字母和大写字母。[a- za -z]+匹配一个或多个字母,^[a- za -z]+$只匹配由一个或多个字母组成的字符串(^和$分别标记字符串的开始和结束)。

如果你想匹配除A-Z之外的其他字母,你可以将它们添加到字符集:[a-zA-ZäöüßÄÖÜ]。或者使用预定义的字符类,如Unicode字符属性类\p{L},它描述了作为字母的Unicode字符。

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 (" # $ % ^ & * ")}" 好吧