list가 주어지면 ['a','ab','abc','bac']
문자열이있는 목록을 계산하고 싶습니다 'ab'
. 즉 결과는 ['ab','abc']
. 파이썬에서 어떻게 할 수 있습니까?
답변:
이 간단한 필터링은 Python을 사용하여 여러 방법으로 달성 할 수 있습니다. 가장 좋은 방법은 다음과 같이 "목록 이해"를 사용하는 것입니다.
>>> lst = ['a', 'ab', 'abc', 'bac']
>>> [k for k in lst if 'ab' in k]
['ab', 'abc']
또 다른 방법은 filter
기능 을 사용하는 것입니다. Python 2 :
>>> filter(lambda k: 'ab' in k, lst)
['ab', 'abc']
Python 3에서는 목록 대신 반복자 를 반환 하지만 캐스트 할 수 있습니다.
>>> list(filter(lambda k: 'ab' in k, lst))
['ab', 'abc']
이해력을 사용하는 것이 더 나은 연습입니다.
lambda
에 완벽한 동반자가 filter
아닐까요? ab
주어진 목록 에 있는지 확인하기 위해 별도의 함수를 작성하는 것은 과잉 이라고 생각합니다 . 따라서 기본적으로 in
연산자를 래핑하는보다 일반적인 함수를 작성하는 것 입니다. 여기 filter
없이 어떻게 더 명확하게 사용 lambda
하시겠습니까?
[x for x in L if 'ab' in x]
# To support matches from the beginning, not any matches:
items = ['a', 'ab', 'abc', 'bac']
prefix = 'ab'
filter(lambda x: x.startswith(prefix), items)
대화 형 셸에서 빠르게 시도했습니다.
>>> l = ['a', 'ab', 'abc', 'bac']
>>> [x for x in l if 'ab' in x]
['ab', 'abc']
>>>
왜 이것이 작동합니까? in
연산자 는 "의 하위 문자열"을 의미하는 문자열에 대해 정의 되기 때문 입니다.
또한 위에서 사용 된 목록 이해 구문 을 사용하는 대신 루프 작성을 고려할 수 있습니다 .
l = ['a', 'ab', 'abc', 'bac']
result = []
for s in l:
if 'ab' in s:
result.append(s)