Python Regex로 반복 패턴 캡처
이메일 주소와 같은 복잡한 패턴을 일치시킬 때 여러 번 나타나는 패턴을 캡처해야 할 수도 있습니다. 특정 하위 패턴. Python의 정규식 모듈에서는 이것이 어려울 수 있습니다.
"yasar@webmail.something.edu.tr"과 같은 이메일 주소를 일치시키는 예를 생각해 보세요. 이메일의 첫 부분을 일치시킨 후 하위 패턴 ".(w )"가 하나 이상 나타나는 것을 캡처할 수 있습니다.
"(.w ) "라는 표현을 사용하려고 시도하는 동안 다음을 깨달았습니다. 마지막 일치 항목만 캡처합니다. 이는 ".something" 및 ".edu" 그룹을 놓치는 것을 의미합니다.
Python의 정규식 모듈에서는 정규식 표준에 있음에도 불구하고 반복 캡처가 지원되지 않습니다. 이러한 이유로 모든 것을 한 번에 캡처한 다음 나중에 하위 패턴을 분할하는 것이 더 효과적인 접근 방식입니다.
다음은 간단한 표현식을 사용하여 이메일 주소를 캡처한 후 하위 패턴을 분할할 수 있는 방법의 예입니다.
import re pattern = r'([.\w]+)@((\w+)(\.\w+)+)' match = re.match(pattern, 'yasar@webmail.something.edu.tr') # Split the subpatterns subpatterns = match.group(2).split('.') # Access the subpatterns print(subpatterns[0]) # 'webmail' print(subpatterns[1]) # 'something' print(subpatterns[2]) # 'edu'
이 방법을 사용하면 반복되는 하위 패턴을 개별적으로 캡처하고 액세스할 수 있어 간단하고 읽기 쉬운 솔루션을 제공할 수 있습니다.
위 내용은 Python Regex에서 하위 패턴의 여러 발생을 캡처하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!