正则表达式从4个字符串中识别正确位置的2个字符

问题描述

例如,我有一个字符串“ abcd”,我希望找到所有匹配项,其中至少有两个匹配的字符在正确的位置。因此,ab12,a1c2、12cd等将全部匹配,因为它们在abcd的正确索引中至少包含2个字符。

我意识到我可以尝试通过/ab..|ac|a..d|.bc.|.bd|.cd/g来执行此操作,但是有没有更好/更简单的方法?>

谢谢!

解决方法

您可以使用PyPi regex软件包轻松地完成此操作。

See code working here

import regex

s = 'abcd'
a = ['ab12','a1c2','12cd','123d','abc4','abcd']

r = regex.compile('(?:'+regex.escape(s)+'){e<=2}')

for x in a:
    if(r.fullmatch(x)):
        print(x)

这使用模糊匹配 {e<=2}来标识具有2个或更少错误(插入,替换,删除)的字符串。如果需要,可以改为指定{s<=2}仅用于替换。

对于列表理解,您可以将以下三行替换为以下内容:

print([x for x in a if(r.fullmatch(x))])

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...