我需要将列表的内容与给定的模式匹配,并形成另一个列表,该列表将包含除匹配项之外的所有内容。意思是,我正在尝试制作一个排除列表。
现在有了一个模式匹配,这很容易。但对于更多的,它变得棘手。
让我们看一个例子:
Lmain=[arc123, arc234,xyz111,xyz222,ppp999,ppp888]
for count in range(len[Lmain]):
if Pattern matches Lmain[i]:
Pass
else:result.append(Lmain[i])
现在让我们说 pattern = arc ,我的结果将是
result = [xyz111,xyz222,ppp999,ppp888]
这只是一个逻辑,我将使用常规 expr 来查找匹配项。
现在,如果我们有 2 个模式,那么在循环中使用上述逻辑:
Pattern=['arc','xyz']
for pat in Pattern:
if pat matches Lmain[i]:
Pass
else:result.append(Lmain[i])
这会给我们错误的结果
result = [xyz111,xyz222,ppp999,ppp888,arc123,arc234,ppp999,ppp888]
所以,你可以看到上面的逻辑是行不通的。
我的计划:
首先,我们找到第一个 Pattern 的排除列表,它会给我们结果:
result = [xyz111,xyz222,ppp999,ppp888]
对于第二种模式,我们需要查看上述结果。
if Pattern matches Result[i]:
Pass
else:result_final.append(Result[i])
我认为我们需要使用递归来实现上述逻辑。现在我们该怎么做呢?我们也不知道用户要输入的模式数量。它可以是一个或多个。
任何人有任何逻辑想法,然后请分享。