在 Python 中查找列表中的子字符串[重复]
- 2025-04-16 08:56:00
- admin 原创
- 16
问题描述:
背景:
示例列表:mylist = ['abc123', 'def456', 'ghi789']
如果存在子字符串匹配项,我想检索该元素,例如abc
代码:
sub = 'abc'
print any(sub in mystring for mystring in mylist)
True
如果列表中有任何元素包含该模式,则上面会打印出来。
我想打印与子字符串匹配的元素。所以如果我要检查的话,'abc'
我只想'abc123'
从列表中打印。
解决方案 1:
print [s for s in list if sub in s]
如果您希望它们用换行符分隔:
print "
".join(s for s in list if sub in s)
完整示例,不区分大小写:
mylist = ['abc123', 'def456', 'ghi789', 'ABC987', 'aBc654']
sub = 'abc'
print "
".join(s for s in mylist if sub.lower() in s.lower())
解决方案 2:
所有答案都有效,但它们总是遍历整个列表。如果我理解你的问题,你只需要第一个匹配项。所以,如果你找到了第一个匹配项,就不必考虑列表的其余部分:
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
解决方案 3:
使用一个简单的for
循环:
seq = ['abc123', 'def456', 'ghi789']
sub = 'abc'
for text in seq:
if sub in text:
print(text)
产量
abc123
解决方案 4:
这将打印所有包含 sub 的元素:
for s in filter (lambda x: sub in x, list): print (s)
解决方案 5:
我只使用一个简单的正则表达式,你可以做这样的事情
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
相关推荐
热门文章
项目管理软件有哪些?
热门标签
曾咪二维码
扫码咨询,免费领取项目管理大礼包!
云禅道AD