我怎么能写一个正则表达式,只匹配字母?
当前回答
你可以试试这个正则表达式:[^\W\d_]或[a-zA-Z]。
其他回答
Pattern pattern = Pattern.compile("^[a-zA-Z]+$");
if (pattern.matcher("a").find()) {
...do something ......
}
JavaScript
如果你想返回匹配的字母:
(123例).match (/ [a - z] / gi) / /结果:[“E”,“x”,“一个”,“m”,“p”,“l”、“E”)
如果你想用星号('*')替换匹配的字母,例如:
(‘Example 123个’)。替换(/[a-z]/gi,'*')//结果:"*******123"*
\p{L}匹配任何Unicode字母,如果您对拉丁字母以外的字母感兴趣
如果你指的是任意字符编码中的任意字母,那么一个很好的方法可能是删除非字母,如空格\s,数字\d,以及其他特殊字符,如:
[!@#\$%\^&\*\(\)\[\]:;'",\. ...more special chars... ]
或者用上述否定的否定来直接描述任何字母:
\S \D and [^ ..special chars..]
优点:
适用于所有正则表达式口味。 容易写,有时节省很多时间。
缺点:
很长,有时并不完美,但字符编码也可能被破坏。
你可以试试这个正则表达式:[^\W\d_]或[a-zA-Z]。