fnmatch.filter()
메서드를 사용하여 목록에서 패턴과 일치하는 문자열을 가져옵니다. fnmatch.filter()
方法从列表中获取匹配模式的字符串。
使用 fnmatch.fnmatch()
方法检查字符串是否与模式匹配。
import fnmatch a_list = ['fql.txt', 'jiyik.txt', 'com.csv'] pattern = '*.txt' filtered_list = fnmatch.filter(a_list, pattern) print(filtered_list) # ????️ ['fql.txt', 'jiyik.txt']
如果我们更愿意使用正则表达式,请向下滚动到下一个副标题。
fnmatch.filter
方法接受一个可迭代对象和一个模式,并返回一个新列表,该列表仅包含与提供的模式匹配的可迭代对象元素。
示例中的模式以任意一个或多个字符开头,以 .txt
结尾。
示例中的模式仅包含一个通配符,但您可以根据需要使用任意多个通配符。
请注意,星号
*
匹配所有内容(一个或多个字符)。
如果要匹配任何单个字符,请将星号 *
替换为问号 ?
。
*
匹配所有内容(一个或多个字符)
?
匹配任何单个字符
[sequence]
匹配序列中的任意字符
[!sequence]
匹配任何不按顺序的字符
下面是使用问号匹配任何单个字符的示例。
import fnmatch a_list = ['abc', 'abz', 'abxyz'] pattern = 'ab?' filtered_list = fnmatch.filter(a_list, pattern) print(filtered_list) # ????️ ['abc', 'abz']
该模式匹配以 ab 开头后跟任何单个字符的字符串。
如果要使用通配符检查字符串是否与模式匹配,请使用 fnmatch.fnmatch()
方法。
import fnmatch a_string = '2023_jiyik.txt' pattern = '2023*.txt' matches_pattern = fnmatch.fnmatch(a_string, pattern) print(matches_pattern) # ????️ True if matches_pattern: # ????️ this runs print('The string matches the pattern') else: print('The string does NOT match the pattern')
该模式以 2023 开头,后跟任意一个或多个字符,并以 .txt 结尾。
fnmatch.fnmatch
方法接受一个字符串和一个模式作为参数。如果字符串与模式匹配,则该方法返回 True,否则返回 False。只需将星号*
替换为问号?
如果您想匹配任何单个字符而不是任何一个或多个字符。
或者,我们可以使用正则表达式。
使用通配符匹配字符串:
使用 re.match()
方法检查字符串是否匹配给定的模式。使用 .*
字符代替通配符。
import re a_list = ['2023_fql.txt', '2023_jiyik.txt', '2023_com.csv'] regex = re.compile(r'2023_.*\.txt') list_of_matches = [ item for item in a_list if re.match(regex, item) ] print(list_of_matches) # ????️ ['2023_fql.txt', '2023_jiyik.txt']
re.compile
方法将正则表达式模式编译成一个对象,该对象可用于使用其 match()
或 search()
方法进行匹配。
这比直接使用 re.match
或 re.search
更有效,因为它保存并重用了正则表达式对象。
正则表达式以 2023_ 开头。
正则表达式中的
.*
字符用作匹配任何一个或多个字符的通配符。
点 .
匹配除换行符以外的任何字符。
星号 *
与前面的正则表达式(点 .
)匹配零次或多次。
我们使用反斜杠字符来转义点。 在扩展名中,因为正如我们之前看到的,点
.
在正则表达式中使用时具有特殊含义。换句话说,我们使用反斜杠来处理点。 作为文字字符。
我们使用列表理解来迭代字符串列表。
列表推导用于对每个元素执行某些操作或选择满足条件的元素子集。
在每次迭代中,我们使用 re.match()
方法检查当前字符串是否与模式匹配。
import re a_list = ['2023_fql.txt', '2023_jiyik.txt', '2023_com.csv'] regex = re.compile(r'2023_.*\.txt') list_of_matches = [ item for item in a_list if re.match(regex, item) ] print(list_of_matches) # ????️ ['2023_fql.txt', '2023_jiyik.txt']
如果提供的正则表达式在字符串中匹配,则 re.match
方法返回一个匹配对象。
如果字符串与正则表达式模式不匹配,则
match()
方法返回 None。
新列表仅包含原始列表中与模式匹配的字符串。
如果只想匹配任何单个字符,请删除点后面的星号 *.
在正则表达式中。
import re a_list = ['2023_a.txt', '2023_bcde.txt', '2023_z.txt'] regex = re.compile(r'2023_.\.txt') list_of_matches = [ item for item in a_list if re.match(regex, item) ] print(list_of_matches) # ????️ ['2023_a.txt', '2023_z.txt']
点 .
匹配除换行符以外的任何字符。
通过使用点
.
在不转义的情况下,正则表达式匹配任何以 2023_ 开头,后跟任何单个字符并以 .txt 结尾的字符串。
如果大家在阅读或编写正则表达式时需要帮助,请参考我们的正则表达式教程。
该页面包含所有特殊字符的列表以及许多有用的示例。
如果想使用正则表达式检查字符串是否与模式匹配,我们可以直接使用 re.match()
fnmatch.fnmatch()
메서드를 사용하세요. 🎜import re a_string = '2023_fql.txt' matches_pattern = bool(re.match(r'2023_.*\.txt', a_string)) print(matches_pattern) # ????️ True if matches_pattern: # ????️ this runs print('The string matches the pattern') else: print('The string does NOT match the pattern')
🎜fnmatch.filter
메서드는 반복 가능 항목과 패턴을 허용하고 제공된 패턴과 일치하는 반복 가능 요소만 포함하는 새 목록을 반환합니다. 🎜
🎜예제의 패턴은 하나 이상의 문자로 시작하고 .txt
로 끝납니다. 🎜🎜예제의 패턴에는 와일드카드가 하나만 포함되어 있지만 원하는 만큼 와일드카드를 사용할 수 있습니다. 🎜
🎜별표 *
는 모든 항목(1개 이상의 문자)과 일치합니다. 🎜
🎜단일 문자와 일치시키려면 별표 *
를 물음표 ?
로 바꾸세요. 🎜🎜🎜🎜*
는 모든 항목(하나 이상의 문자)과 일치합니다. 🎜🎜🎜?
는 단일 문자와 일치합니다. 🎜🎜🎜[ 시퀀스]
시퀀스의 모든 문자와 일치🎜🎜🎜[!sequence]
시퀀스 밖의 모든 문자와 일치🎜🎜다음은 예입니다. 물음표를 사용하여 단일 문자와 일치시킵니다. 🎜import re a_string = '2023_ABC.txt' matches_pattern = bool(re.match(r'2023_.\.txt', a_string)) print(matches_pattern) # ????️ False if matches_pattern: print('The string matches the pattern') else: # ????️ this runs print('The string does NOT match the pattern')
fnmatch.fnmatch()
메서드를 사용하세요. 🎜rrreee🎜 패턴은 2023으로 시작하고 그 뒤에 하나 이상의 문자가 오고 .txt로 끝납니다. 🎜🎜🎜또는 정규식을 사용할 수도 있습니다. 🎜🎜정규식을 사용하여 와일드카드를 사용하여 문자열 일치🎜🎜와일드카드를 사용하여 문자열 일치:🎜🎜fnmatch.fnmatch
메소드는 문자열과 패턴을 매개변수로 허용합니다. 이 메서드는 문자열이 패턴과 일치하면 True를 반환하고, 그렇지 않으면 False를 반환합니다. 하나 이상의 문자 대신 단일 문자와 일치시키려면 별표*
를 물음표?
로 바꾸십시오. 🎜
re.match()
메서드를 사용하여 문자열이 주어진 문자열과 일치하는지 확인하세요. 모델. 와일드카드 문자 대신 .*
문자를 사용하세요. 🎜rrreee🎜 re.compile
메소드는 정규 표현식 패턴을 match()
또는 search()
와 함께 사용할 수 있는 객체로 컴파일합니다. 일치시키는 방법. 🎜🎜정규식 개체를 저장하고 재사용하므로 re.match
또는 re.search
를 직접 사용하는 것보다 더 효율적입니다. 🎜🎜정규 표현식은 2023_으로 시작합니다. 🎜🎜정규식의 .*
문자는 하나 이상의 문자와 일치하는 와일드카드로 사용됩니다. 🎜
🎜🎜🎜Dot .
는 개행 문자를 제외한 모든 문자와 일치합니다. 🎜🎜🎜별표 *
는 앞의 정규식(점 .
)과 0번 이상 일치합니다. 🎜🎜점을 이스케이프 처리하기 위해 백슬래시 문자를 사용합니다. 확장에서 앞서 본 것처럼 .
점은 정규식에서 사용될 때 특별한 의미를 갖기 때문입니다. 즉, 점을 처리하기 위해 백슬래시를 사용합니다. 리터럴 문자로. 🎜
🎜우리는 목록 이해를 사용하여 문자열 목록을 반복합니다. 🎜🎜List comprehension은 각 요소에 대해 특정 작업을 수행하거나 조건을 충족하는 요소의 하위 집합을 선택하는 데 사용됩니다. 🎜🎜각 반복에서 re.match()
메서드를 사용하여 현재 문자열이 패턴과 일치하는지 확인합니다. 🎜rrreee🎜 re.match
메서드는 제공된 정규 표현식이 문자열에서 일치하는 경우 일치 개체를 반환합니다. 🎜🎜문자열이 정규식 패턴과 일치하지 않으면 match()
메서드는 None을 반환합니다. 🎜
🎜새 목록에는 패턴과 일치하는 원본 목록의 문자열만 포함됩니다. 🎜🎜단일 문자만 일치시키려면 정규식에서 점 *.
뒤의 별표를 제거하세요. 🎜rrreee🎜Dot .
는 개행 문자를 제외한 모든 문자와 일치합니다. 🎜🎜이스케이프 없이 점 .
을 사용하면 정규식은 2023_으로 시작하고 그 뒤에 txt로 끝나는 모든 단일 문자와 일치합니다. 끝에 문자열입니다. 🎜
🎜정규식을 읽거나 작성하는 데 도움이 필요하면 정규식 튜토리얼을 참조하세요. 🎜🎜이 페이지에는 모든 특수 문자 목록과 많은 유용한 예가 포함되어 있습니다. 🎜🎜문자열이 패턴과 일치하는지 확인하기 위해 정규식을 사용하려면 re.match()
메서드를 직접 사용할 수 있습니다. 🎜import re a_string = '2023_fql.txt' matches_pattern = bool(re.match(r'2023_.*\.txt', a_string)) print(matches_pattern) # ????️ True if matches_pattern: # ????️ this runs print('The string matches the pattern') else: print('The string does NOT match the pattern')
如果字符串与模式匹配,则
re.match()
方法将返回一个匹配对象,如果不匹配,则返回 None 。
我们使用 bool()
类将结果转换为布尔值。
如果要对单个字符使用通配符,请删除星号 *
。
import re a_string = '2023_ABC.txt' matches_pattern = bool(re.match(r'2023_.\.txt', a_string)) print(matches_pattern) # ????️ False if matches_pattern: print('The string matches the pattern') else: # ????️ this runs print('The string does NOT match the pattern')
请注意
,点.
我们没有使用反斜杠作为前缀用于匹配任何单个字符,而点.
我们以反斜杠 \ 为前缀的被视为文字点。
示例中的字符串与模式不匹配,因此 matches_pattern
变量存储一个 False 值。
위 내용은 Python에서 와일드카드를 사용하여 문자열을 일치시키는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!