135

バックグラウンド:

リストの例:mylist = ['abc123', 'def456', 'ghi789']

次のような部分文字列に一致するものがある場合、要素を取得したいabc

コード:

sub = 'abc'
print any(sub in mystring for mystring in mylist)

上記Trueは、リスト内の要素のいずれかにパターンが含まれている場合に出力されます。

部分文字列に一致する要素を印刷したいと思います。したがって、チェックしている場合は、リストから'abc'のみ印刷したいと思い'abc123'ます。

4

5 に答える 5

169
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())
于 2012-12-08T16:49:22.473 に答える
73

すべての答えは機能しますが、常にリスト全体を横断します。私があなたの質問を理解しているなら、あなたは最初の試合だけが必要です。したがって、最初の一致が見つかった場合は、リストの残りの部分を考慮する必要はありません。

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
于 2015-05-12T17:33:44.150 に答える
24

単純なforループを使用します。

seq = ['abc123', 'def456', 'ghi789']
sub = 'abc'

for text in seq:
    if sub in text:
        print(text)

収量

abc123
于 2012-12-08T16:49:24.010 に答える
11

単純な正規表現を使用するだけです。次のようなことができます

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
于 2012-12-08T16:56:31.053 に答える
10

これにより、subを含むすべての要素が出力されます。

for s in filter (lambda x: sub in x, list): print (s)
于 2012-12-08T16:49:27.200 に答える