>백엔드 개발 >파이썬 튜토리얼 >Python 정규식으로 문자열을 일치시키는 방법

Python 정규식으로 문자열을 일치시키는 방법

coldplay.xixi
coldplay.xixi원래의
2020-10-29 10:18:4620662검색

Python 정규 표현식으로 문자열을 일치시키는 방법: 1. 정규 표현식 [(.+?)]을 사용하여 단일 위치에서 문자열을 추출합니다. 2. 정규 표현식 [(?P...)]을 사용합니다. 문자열의 여러 연속 위치와 일치합니다.

Python 정규식으로 문자열을 일치시키는 방법

관련 무료 학습 권장사항: python 동영상 튜토리얼

Python 정규식 일치 문자열 방법:

1. 단일 위치에서 문자열 추출

이에는 이 경우 정규식 (.+?)를 사용하여 추출할 수 있습니다. 예를 들어 문자열 "a123b"의 경우 ab 사이의 값 123을 추출하려면 정규식과 함께 findall을 사용할 수 있습니다. 그러면 일치하는 모든 상황이 포함된 목록이 반환됩니다. (.+?)这个正则表达式来提取。 举例,一个字符串"a123b",如果我们想提取ab之间的值123,可以使用findall配合正则表达式,这样会返回一个包含所以符合情况的list。

代码如下:

import re
str = "a123b"
print re.findall(r"a(.+?)b",str)#
输出['123']

1.1贪婪和非贪婪匹配

如果我们有一个字符串”a123b456b”,如果我们想匹配a和最后一个b之间的所有值而非a和第一个出现的b之间的值,可以用?来控制正则贪婪和非贪婪匹配的情况。

代码如下:

import re
str = "a123b456b"
 
print re.findall(r"a(.+?)b", str)
#输出['123']#?控制只匹配0或1个,所以只会输出和最近的b之间的匹配情况
 
print re.findall(r"a(.+)b", str)
#输出['123b456']
 
print re.findall(r"a(.*)b", str)
#输出['123b456']

1.2多行匹配

如果你要多行匹配,那么需要加上re.S和re.M标志. 加上re.S后。将会匹配换行符,默认.不会匹配换行符。

代码如下:

str = "a23b\na34b"
 
re.findall(r"a(\d+)b.+a(\d+)b", str)
#输出[]
#因为不能处理str中间有\n换行的情况
 
re.findall(r"a(\d+)b.+a(\d+)b", str, re.S)
#s输出[('23', '34')]

加上re.M后,^$标志将会匹配每一行,默认^和$只会匹配第一行。

代码如下:

str = "a23b\na34b"
 
re.findall(r"^a(\d+)b", str)
#输出['23']
 
re.findall(r"^a(\d+)b", str, re.M)
#输出['23', '34']

二、连续多个位置的字符串提取

这种情况我们可以使用(?P8a11bc632ea32a57b3e3693c7987c420…)这个正则表达式来提取。举例,如果我们有一行webserver的access日志:'192.168.0.1 25/Oct/2012:14:46:34 "GET /api HTTP/1.1" 200 44 "http://abc.com/search" "Mozilla/5.0"',我们想提取这行日志里面所有的内容,可以写多个(?P8a11bc632ea32a57b3e3693c7987c420expr)

코드는 다음과 같습니다.

import re
line ='192.168.0.1 25/Oct/2012:14:46:34 "GET /api HTTP/1.1" 200 44 "http://abc.com/search"
"Mozilla/5.0"'
reg = re.compile(&#39;^(?P<remote_ip>[^ ]*) (?P<date>[^ ]*) "(?P<request>[^"]*)" 
(?P<status>[^ ]*) (?P<size>[^ ]*) "(?P<referrer>[^"]*)" "(?P<user_agent>[^"]*)"&#39;)
regMatch = reg.match(line)
linebits = regMatch.groupdict()
print linebits
for k, v in linebits.items() :
 print k+": "+v

1.1 탐욕적 일치와 비탐욕적 일치

🎜🎜문자열 "a123b456b"가 있는 경우 a와 대신 a와 마지막 b 사이의 모든 값을 일치시키려는 경우 첫 번째 발생 b 사이의 값은 일반적인 탐욕 매칭과 비탐욕 매칭을 제어하는 ​​데 사용될 수 있습니다. 🎜🎜코드는 다음과 같습니다. 🎜
status: 200
referrer: 
request: GET /api HTTP/1.1
user_agent: Mozilla/5.0
date: 25/Oct/2012:14:46:34size: 44
remote_ip: 192.168.0.1
🎜🎜1.2 다중 행 일치🎜🎜🎜 다중 행 일치를 원할 경우 re.S를 추가한 후 re.S 및 re.M 플래그를 추가해야 합니다. 개행 문자와 일치합니다. 기본값은 개행 문자와 일치하지 않습니다. 🎜🎜코드는 다음과 같습니다. 🎜rrreee🎜re.M을 추가한 후에는 ^$ 기호가 각 줄과 일치합니다. 기본적으로 ^와 $는 첫 번째 줄에만 일치합니다. 🎜🎜코드는 다음과 같습니다. 🎜rrreee🎜🎜2. 연속된 여러 위치의 문자열 추출🎜🎜🎜이 경우 정규식 (?P8a11bc632ea32a57b3e3693c7987c420…)을 사용하여 발췌. 예를 들어, 웹 서버의 액세스 로그 라인이 있는 경우:'192.168.0.1 25/Oct/2012:14:46:34 "GET /api HTTP/1.1" 200 44 "http://abc.com/ search" "Mozilla/5.0"', 우리는 이 로그 줄의 모든 내용을 추출하고 싶습니다. 추출할 (?P8a11bc632ea32a57b3e3693c7987c420expr)을 여러 개 작성할 수 있으며, name은 사용자가 변경할 수 있습니다. 위치 문자열로 명명된 변수는 위치 추출을 위한 정규식으로 expr을 변경할 수 있습니다. 🎜🎜코드는 다음과 같습니다. 🎜rrreee🎜출력 결과는 🎜rrreee입니다.

위 내용은 Python 정규식으로 문자열을 일치시키는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.