두 문자열 사이의 일치 항목을 추출하는 정규식
특정 시작 및 끝 마커로 묶인 여러 줄 문자열이 포함된 대용량 로그 파일이 있는 경우 목표는 가장 짧은 문자열만 추출하여 인쇄하는 것입니다. 그러나 시작 마커는 파일의 다른 곳에서 사용되므로 간단한 정규식으로는 충분하지 않습니다.
이 문제를 해결하려면 다음 정규식을 사용할 수 있습니다.
(start((?!start).)*?end)
이 정규식은 다음과 일치합니다. 다음 문자열:
사용 한 줄 수정자(re.S)를 사용하는 Python의 re.findall 메소드를 사용하면 입력 파일에서 이러한 모든 문자열을 검색할 수 있습니다.
<code class="python">import re text = """ start spam start rubbish start wait for it... profit! here end start garbage start second match win. end """ matches = re.findall('(start((?!start).)*?end)', text, re.S) print(matches)</code>
이렇게 하면 원하는 결과가 출력됩니다.
['start wait for it... profit! here end', 'start second match win. end']
위 내용은 정규식을 사용하여 로그의 두 문자열 간의 일치 항목을 추출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!