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


当前回答

如果你指的是任意字符编码中的任意字母,那么一个很好的方法可能是删除非字母,如空格\s,数字\d,以及其他特殊字符,如:

[!@#\$%\^&\*\(\)\[\]:;'",\. ...more special chars... ]

或者用上述否定的否定来直接描述任何字母:

\S \D and [^  ..special chars..]

优点:

适用于所有正则表达式口味。 容易写,有时节省很多时间。

缺点:

很长,有时并不完美,但字符编码也可能被破坏。

其他回答

最接近的选择是

[\u\l]+

匹配大写字母和小写字母的序列。但是,并非所有编辑器/语言都支持它,因此使用它可能更安全

[a-zA-Z]+

正如其他用户所说

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

对于PHP,下面的代码就可以了

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

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

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

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