我怎么能写一个正则表达式,只匹配字母?
当前回答
你可以用
/[a-z]/gi
[]——检查给定输入之间的任何字符
A-z,涵盖了整个字母表
G -----在整个字符串中
我-----得到大写和小写
其他回答
你可以用
/[a-z]/gi
[]——检查给定输入之间的任何字符
A-z,涵盖了整个字母表
G -----在整个字符串中
我-----得到大写和小写
对于PHP,下面的代码就可以了
'/^[a-zA-Z]+$/'
这取决于你对“性格”的理解:
[A-Za-z] -所有字母(大写和小写)
[^0-9] -所有非数字字符
如果你指的是任意字符编码中的任意字母,那么一个很好的方法可能是删除非字母,如空格\s,数字\d,以及其他特殊字符,如:
[!@#\$%\^&\*\(\)\[\]:;'",\. ...more special chars... ]
或者用上述否定的否定来直接描述任何字母:
\S \D and [^ ..special chars..]
优点:
适用于所有正则表达式口味。 容易写,有时节省很多时间。
缺点:
很长,有时并不完美,但字符编码也可能被破坏。
所以,我读了很多答案,大部分答案都没有考虑到例外情况,比如有重音的字母或变音(á, à, ä等)。
我在typescript中编写了一个函数,该函数应该几乎可以外推到任何可以使用RegExp的语言。这是我个人用TypeScript实现的用例。我所做的基本上是为我想添加的每种符号添加字母范围。在应用RegExp之前,我还将字符转换为大写,这为我节省了一些工作。
function isLetter(char: string): boolean {
return char.toUpperCase().match('[A-ZÀ-ÚÄ-Ü]+') !== null;
}
如果您想添加具有另一种重音的另一个字母范围,只需将其添加到正则表达式。特殊符号也是如此。
我用TDD实现了这个功能,我可以确认这至少适用于以下情况:
character | isLetter
${'A'} | ${true}
${'e'} | ${true}
${'Á'} | ${true}
${'ü'} | ${true}
${'ù'} | ${true}
${'û'} | ${true}
${'('} | ${false}
${'^'} | ${false}
${"'"} | ${false}
${'`'} | ${false}
${' '} | ${false}
推荐文章
- 如何从JavaScript中使用正则表达式的字符串中剥离所有标点符号?
- 正则表达式中的单词边界是什么?
- 如何将一个标题转换为jQuery的URL段塞?
- Javascript和regex:分割字符串并保留分隔符
- (grep)正则表达式匹配非ascii字符?
- 如何在保持原始字符串的同时对字符串执行Perl替换?
- 创建正则表达式匹配数组
- *的区别是什么?和。*正则表达式?
- 如何将“camelCase”转换为“Camel Case”?
- 在Java中使用正则表达式提取值
- Java中的正则表达式命名组
- 使用正则表达式搜索和替换Visual Studio代码
- 使用split("|")按管道符号拆分Java字符串
- 替换字符串中第一次出现的模式
- “\d”在正则表达式中是数字吗?