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


当前回答

正则表达式,很少有人写为“/^[a-zA-Z]$/i”是不正确的,因为最后他们提到了/i,这是不区分大小写的,在第一次匹配后,它将返回。用/g代替/i,它是全局的,你也不需要用^ $作为开始和结束。

/[a-zA-Z]+/g

[a-z_]+匹配下面列表中的单个字符 量词:+在一到无限次之间,尽可能多的次数,在需要的时候回馈 a-z在a和z之间的单个字符(区分大小写) a -Z在a和Z之间的单个字符(区分大小写) G修饰符:全局。所有比赛(第一场比赛不返回)

其他回答

只需使用\w或[:alpha:]即可。它是一个转义序列,只匹配可能出现在单词中的符号。

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 (" # $ % ^ & * ")}" 好吧

你可以试试这个正则表达式:[^\W\d_]或[a-zA-Z]。

这取决于你对“性格”的理解:

[A-Za-z] -所有字母(大写和小写)

[^0-9] -所有非数字字符

所以,我读了很多答案,大部分答案都没有考虑到例外情况,比如有重音的字母或变音(á, à, ä等)。

我在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}