2

我有正则表达式可以在字符串中找到长度为 6 的字母数字。字符串如下所示:

PLT\n\nTRAVELLER NAME LIST\n\n     TRAVELLER              RECLOC COMPANY\n   1          TESTNUMBERFIVEQA/TESTN WL9795\n   2 TESTNUMBERONEYQWA/TEST RHFQCD\n   3 TESTNUMBERONEYQWAZZZ/T 1QZ1JF\n   4 TESTNUMBERONEYQWAZZZM/ N3BZW8\n   5 TESTNUMBERONEYQWAZZZMK 05RXPM\n   6 TESTNUMBERONEYQWAZZZMK 2XR9ZR\n   7 TESTNUMBERTHREEZZZ/TES 0Q14S4\n   8 TESTNUMBERTHREEZZZM/TE LRRKW3\n   9 TESTNUMBERTHREEZZZMK/T 949Z4T\n  10 TESTNUMBERTHREEZZZMKJ/ 51WFM2\n  11 TESTNUMBERTWOZZA/TESTN PRGWVT\n  12 TESTNUMBERTWOZZAZZZ/TE SM0BHS\n  13 TESTNUMBERTWOZZAZZZM/T QRJLH1\n  14 TESTNUMBERTWOZZAZZZMK/ R69NHV\n  15 TESTNUMBERTWOZZAZZZMKJ 67XKF7\n  16 TESTNUMBERTWOZZAZZZMKJ 68PV7P\n  17 TESTNUMBERTWOZZAZZZMKJ GCZZ0C\n)>  18 TESTNUMBERTWOZZAZZZMKJ MLMS3L\n  19 TESTNUMBERTWOZZAZZZMKJ 3R1S49\n  20 TESTNUMBERTWOZZAZZZMKJ WB700R\n  21 TESTNUMBERTWOZZAZZZMKJ 718KRC\n  22 TESTNUMBERTWOZZAZZZMKJ RTQH2H\n  23 TESTNUMBERTWOZZAZZZMKJ N2FLM6\n  24 TESTNUMBERTWOZZAZZZMKJ 40M1FR\n  25 TESTNUMBERTWOZZAZZZMKJ 71D3HF\n  26

我尝试过的正则表达式是这样的:

for k in mainString:
    m = re.match('([0-9A-Z]{6})', k)
    if (m):
        do something

但它没有按预期工作。有人能指出我可能在哪里犯错吗?我正在寻找的模式就像 WL9795、RHFQCD 等。

谢谢

4

2 回答 2

5

match方法仅检查字符串开头的匹配项。

改用这个search方法!

此外,这些()都是不必要的。

如果mainString在您的代码中实际上是问题顶部的字符串,那么您的代码将无法正常工作,因为for循环将遍历该字符串中的所有单个字符。

相反,您可以使用

m = re.search(r'\b[0-9A-Z]{6}\b', mainString)
if (m):
    print(m.group())

r则表达式之前的 确保\b不被视为字符串转义序列。

\b平均单词边界并确保 6 个字母数字字符的前面或后面没有单词字符。没有他们,第一场比赛将是"TRAVEL"in "TRAVELLER"

如果您想获取所有匹配项的列表,请使用findallorfinditer而不是search.

for m in re.finditer(r'\b[0-9A-Z]{6}\b', mainString):
    print(m.group())
于 2013-04-16T17:51:46.337 回答
3

在我看来,您可能需要一些单词边界:

>>> print re.findall(r'\b\w{6}\b',s)
['RECLOC', 'WL9795', 'RHFQCD', '1QZ1JF', 'N3BZW8', '05RXPM', '2XR9ZR', '0Q14S4', 'LRRKW3', '949Z4T', '51WFM2', 'PRGWVT', 'SM0BHS', 'QRJLH1', 'R69NHV', '67XKF7', '68PV7P', 'GCZZ0C', 'MLMS3L', '3R1S49', 'WB700R', '718KRC', 'RTQH2H', 'N2FLM6', '40M1FR', '71D3HF']

此正则表达式匹配完全是字符长度的字母数字模式。换句话说,它不匹配任何东西,"foobarbaz"但它会匹配foobarfrom"foobar."

于 2013-04-16T17:56:57.880 回答