リストの例:mylist = ['abc123', 'def456', 'ghi789']
abc
のような部分文字列に一致する場合、要素を取得したい
sub = 'abc'
print any(sub in mystring for mystring in mylist)
リストの要素のいずれかにパターンが含まれている場合、上記はTrue
を出力します。
部分文字列に一致する要素を印刷したいと思います。したがって、'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())
すべての答えは機能しますが、リスト全体を常に横断します。あなたの質問を理解したら、最初の一致だけが必要です。したがって、最初に一致したものが見つかった場合、リストの残りを考慮する必要はありません。
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)
私は単純な正規表現を使用します、あなたはこのようなことをすることができます
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