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


当前回答

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

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

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

其他回答

/[a-zA-Z]+/

非常简单的例子。正则表达式在网上非常容易找到。

http://www.regular-expressions.info/reference.html

如果你指的是任意字符编码中的任意字母,那么一个很好的方法可能是删除非字母,如空格\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修饰符:全局。所有比赛(第一场比赛不返回)

你可以用

/[a-z]/gi

[]——检查给定输入之间的任何字符

A-z,涵盖了整个字母表

G -----在整个字符串中

我-----得到大写和小写

JavaScript

如果你想返回匹配的字母:

(123例).match (/ [a - z] / gi) / /结果:[“E”,“x”,“一个”,“m”,“p”,“l”、“E”)

如果你想用星号('*')替换匹配的字母,例如:

(‘Example 123个’)。替换(/[a-z]/gi,'*')//结果:"*******123"*