python:查找列表中的子string

这是工作,但经过几个小时的挫折和彻底search堆栈我仍然有一些奇怪的行为。

背景:

示例列表: list = ['abc123', 'def456', 'ghi789']

我想检索一个元素,如果有一个匹配的子string,如abc

码:

 sub = 'abc' if any(sub in string for string in list): print string 

它可以工作,但它打印列表中的每个元素。 同样,如果我尝试

print any(sub in string for string in list)

它将为列表中的每个元素输出True

我只想打印与子string匹配的列表中的元素。 所以如果我检查'abc'我只想从列表中打印'abc123'

 print [s for s in list if sub in s] 

如果你想让他们用换行符隔开:

 print "\n".join(s for s in list if sub in s) 

完整的例子,不区分大小写:

 mylist = ['abc123', 'def456', 'ghi789', 'ABC987', 'aBc654'] sub = 'abc' print "\n".join(s for s in mylist if sub.lower() in s.lower()) 

所有答案的工作,但他们总是遍历整个列表。 如果我理解你的问题,你只需要第一场比赛。 所以,如果你find你的第一个匹配,你不必考虑清单的其余部分:

 mylist = ['abc123', 'def456', 'ghi789'] sub = 'abc' next((s for s in mylist if sub in s), None) # returns 'abc123' 

如果匹配是在列表的末尾或者是非常小的列表,那么没有什么区别,但是考虑一下这个例子:

 import timeit mylist = ['abc123'] + ['xyz123']*1000 sub = 'abc' timeit.timeit('[s for s in mylist if sub in s]', setup='from __main__ import mylist, sub', number=100000) # for me 7.949463844299316 with Python 2.7, 8.568840944994008 with Python 3.4 timeit.timeit('next((s for s in mylist if sub in s), None)', setup='from __main__ import mylist, sub', number=100000) # for me 0.12696599960327148 with Python 2.7, 0.09955992100003641 with Python 3.4 

如何简单的for循环:

 seq = ['abc123', 'def456', 'ghi789'] sub = 'abc' for text in seq: if sub in text: print(text) 

产量

 abc123 

这将打印包含sub的所有元素:

 for s in filter (lambda x: sub in x, list): print (s) 

我只是使用一个简单的正则expression式,你可以做这样的事情

 import re old_list = ['abc123', 'def456', 'ghi789'] new_list = [x for x in old_list if re.search('abc', x)] for item in new_list: print item