作者:手机用户2502918695 | 来源:互联网 | 2024-09-25 14:14
我需要一个正则表达式来匹配每行中第一个单词中带有字符“ a”的单词。例如我的测试字符串是这样的:
bbsc abcd aaaagdhskss
dsaa asdd aaaagdfhdghd
wwww awww wwwd
只有粗体字体应该匹配。我怎样才能做到这一点?我可以将所有带有“ a”的单词进行匹配,但无法弄清楚如何仅匹配第一个出现的单词。
假设仅使用的字符是 word 个字符,即\w
个字符,然后使用空格,则使用:
/^(?:[^a ]+ +)*([^a ]*a\w*)\b/gm
-
^
匹配行的开头
-
(?:[^a ]+ +)*
匹配0次或更多次出现的,由a
以外的任何字符组成的单词,然后在一个非捕获组中匹配一个或多个空格。
-
([^a ]*a\w*)\b
与包含a
的以单词边界结尾的单词(已经保证从单词边界开始)匹配。单词边界约束允许单词在行尾。
其中带有a
的第一个单词将在#1组中。
See demo
如果我们不能假设仅出现单词(\w
)和空格字符,请使用:
^(?:[^a ]+ +)*(\w*a\w*)\b
区别在于扫描其中带有a
的第一个单词(\w*a\w*)
,我们可以保证扫描的是仅包含单词字符的字符串。
,
您正在使用什么?在许多程序中,您可以设置限制。可能的话:\b[b-z]*a[a-z]*
,限制为1。
如果不可能,请使用组来捕获并匹配后者:([b-z]*a[a-z]*).*
,
尝试:
^(?:[^a ]+ )*(\w*a\w*) .*$
基本上说的是:捕获一堆由除字母a
(或
)之外的任何东西组成的单词,然后捕获一个必须包含字母a
。
第1组应包含a
的第一个单词。