Python 정규 표현식으로 문자열을 일치시키는 방법: 1. 정규 표현식 [(.+?)]을 사용하여 단일 위치에서 문자열을 추출합니다. 2. 정규 표현식 [(?P
...)]을 사용합니다. 문자열의 여러 연속 위치와 일치합니다.
관련 무료 학습 권장사항: 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']
二、连续多个位置的字符串提取
这种情况我们可以使用(?P<name>…)
这个正则表达式来提取。举例,如果我们有一行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"'
,我们想提取这行日志里面所有的内容,可以写多个(?P<name>expr)
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('^(?P<remote_ip>[^ ]*) (?P<date>[^ ]*) "(?P<request>[^"]*)" (?P<status>[^ ]*) (?P<size>[^ ]*) "(?P<referrer>[^"]*)" "(?P<user_agent>[^"]*)"') 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
(?P<name>…)
을 사용하여 발췌. 예를 들어, 웹 서버의 액세스 로그 라인이 있는 경우:'192.168.0.1 25/Oct/2012:14:46:34 "GET /api HTTP/1.1" 200 44 "http://abc.com/ search" "Mozilla/5.0"'
, 우리는 이 로그 줄의 모든 내용을 추출하고 싶습니다. 추출할 (?P<name>expr)
을 여러 개 작성할 수 있으며, name은 사용자가 변경할 수 있습니다. 위치 문자열로 명명된 변수는 위치 추출을 위한 정규식으로 expr을 변경할 수 있습니다. 🎜🎜코드는 다음과 같습니다. 🎜rrreee🎜출력 결과는 🎜rrreee입니다.위 내용은 Python 정규식으로 문자열을 일치시키는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!