我怎么能写一个正则表达式,只匹配字母?
当前回答
Java:
String s= "abcdef";
if(s.matches("[a-zA-Z]+")){
System.out.println("string only contains letters");
}
其他回答
使用字符集:[a- za -z]匹配a-z中的一个小写字母和大写字母。[a- za -z]+匹配一个或多个字母,^[a- za -z]+$只匹配由一个或多个字母组成的字符串(^和$分别标记字符串的开始和结束)。
如果你想匹配除A-Z之外的其他字母,你可以将它们添加到字符集:[a-zA-ZäöüßÄÖÜ]。或者使用预定义的字符类,如Unicode字符属性类\p{L},它描述了作为字母的Unicode字符。
\p{L}匹配任何Unicode字母,如果您对拉丁字母以外的字母感兴趣
你可以用
/[a-z]/gi
[]——检查给定输入之间的任何字符
A-z,涵盖了整个字母表
G -----在整个字符串中
我-----得到大写和小写
如果你指的是任意字符编码中的任意字母,那么一个很好的方法可能是删除非字母,如空格\s,数字\d,以及其他特殊字符,如:
[!@#\$%\^&\*\(\)\[\]:;'",\. ...more special chars... ]
或者用上述否定的否定来直接描述任何字母:
\S \D and [^ ..special chars..]
优点:
适用于所有正则表达式口味。 容易写,有时节省很多时间。
缺点:
很长,有时并不完美,但字符编码也可能被破坏。
正则表达式,很少有人写为“/^[a-zA-Z]$/i”是不正确的,因为最后他们提到了/i,这是不区分大小写的,在第一次匹配后,它将返回。用/g代替/i,它是全局的,你也不需要用^ $作为开始和结束。
/[a-zA-Z]+/g
[a-z_]+匹配下面列表中的单个字符 量词:+在一到无限次之间,尽可能多的次数,在需要的时候回馈 a-z在a和z之间的单个字符(区分大小写) a -Z在a和Z之间的单个字符(区分大小写) G修饰符:全局。所有比赛(第一场比赛不返回)