我怎么能写一个正则表达式,只匹配字母?
当前回答
JavaScript
如果你想返回匹配的字母:
(123例).match (/ [a - z] / gi) / /结果:[“E”,“x”,“一个”,“m”,“p”,“l”、“E”)
如果你想用星号('*')替换匹配的字母,例如:
(‘Example 123个’)。替换(/[a-z]/gi,'*')//结果:"*******123"*
其他回答
使用字符集:[a- za -z]匹配a-z中的一个小写字母和大写字母。[a- za -z]+匹配一个或多个字母,^[a- za -z]+$只匹配由一个或多个字母组成的字符串(^和$分别标记字符串的开始和结束)。
如果你想匹配除A-Z之外的其他字母,你可以将它们添加到字符集:[a-zA-ZäöüßÄÖÜ]。或者使用预定义的字符类,如Unicode字符属性类\p{L},它描述了作为字母的Unicode字符。
pattern = /[a-zA-Z]/
输入“[a-zA-Z]: #{模式。match("mine blossom")}"好的
[a-zA-Z]: #{pattern.match("456")}"
[a-zA-Z]: #{pattern.match("")}"
输入"[a-zA-Z]: #{pattern.match("#$%^&*")}"
把“[a-zA-Z]: # {pattern.match (" # $ % ^ & * ")}" 好吧
/[a-zA-Z]+/
非常简单的例子。正则表达式在网上非常容易找到。
http://www.regular-expressions.info/reference.html
所以,我读了很多答案,大部分答案都没有考虑到例外情况,比如有重音的字母或变音(á, à, ä等)。
我在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}
/^[A-z]+$/.test('asd')
// true
/^[A-z]+$/.test('asd0')
// false
/^[A-z]+$/.test('0asd')
// false