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