반응형
문자열이 목록의 문자열 중 하나로 끝나는지 확인합니다.
다음 코드를 쓰는 비토닉 방식은 무엇입니까?
extensions = ['.mp3','.avi']
file_name = 'test.mp3'
for extension in extensions:
if file_name.endswith(extension):
#do stuff
나는 어렴풋이 기억한다 그 명시적인 선언은for
루프를 회피할 수 있으며 루프를 에 쓸 수 있습니다.if
조건.정말이에요?
널리 알려지지는 않았지만 str.endswith는 태플도 받아들인다.루프할 필요 없어요.
>>> 'test.mp3'.endswith(('.mp3', '.avi'))
True
사용방법:
if file_name.endswith(tuple(extensions)):
정규 표현과 스트링(str) 메서드의 2가지 방법이 있습니다.
스트링 메서드는 보통 고속입니다(~2x).
import re, timeit
p = re.compile('.*(.mp3|.avi)$', re.IGNORECASE)
file_name = 'test.mp3'
print(bool(t.match(file_name))
%timeit bool(t.match(file_name)
루프당 792ns ± 1.83ns(평균 ± 표준).dev. 7회 주행 중 각각 1000000회 루프)
file_name = 'test.mp3'
extensions = ('.mp3','.avi')
print(file_name.lower().endswith(extensions))
%timeit file_name.lower().endswith(extensions)
루프당 274ns ± 4.22ns(평균 ± 표준).dev. 7회 주행 중 각각 1000000회 루프)
일치하는 문자열 목록을 반환할 수 있는 또 다른 방법은
sample = "alexis has the control"
matched_strings = filter(sample.endswith, ["trol", "ol", "troll"])
print matched_strings
['trol', 'ol']
다른 걸 찾다가 우연히 발견했어요.
다음 방법을 사용할 것을 권장합니다.os
패키지.그 이유는 이상한 경우를 보상하면서 좀 더 일반적인 것으로 만들 수 있기 때문입니다.
다음과 같은 작업을 수행할 수 있습니다.
import os
the_file = 'aaaa/bbbb/ccc.ddd'
extensions_list = ['ddd', 'eee', 'fff']
if os.path.splitext(the_file)[-1] in extensions_list:
# Do your thing.
이거 있어요.
def has_extension(filename, extension):
ext = "." + extension
if filename.endswith(ext):
return True
else:
return False
다른 방법으로는 IN 문을 사용할 수 있습니다.
extensions = ['.mp3','.avi']
file_name = 'test.mp3'
if "." in file_name and file_name[file_name.rindex("."):] in extensions:
print(True)
언급URL : https://stackoverflow.com/questions/18351951/check-if-string-ends-with-one-of-the-strings-from-a-list
반응형
'programing' 카테고리의 다른 글
본문 요소에 커스텀클래스를 추가하려고 하면 Nuxt JS에서 SSR 인코딩 오류가 발생하는 이유는 무엇입니까? (0) | 2022.12.07 |
---|---|
Java를 사용하여 디렉토리의 모든 파일을 재귀적으로 나열 (0) | 2022.12.07 |
MariaDB/Mediawiki의 다중 행 정규식 일치 (0) | 2022.12.07 |
Vue: 하나의 웹사이트에서 여러 개의 Vue 앱을 사용할 수 있습니까? (0) | 2022.12.07 |
PHP var_dump와 동등한 Java는 무엇입니까? (0) | 2022.12.07 |