Maison  >  Article  >  développement back-end  >  Comment faire correspondre une chaîne avec une expression régulière Python

Comment faire correspondre une chaîne avec une expression régulière Python

coldplay.xixi
coldplay.xixioriginal
2020-10-29 10:18:4620445parcourir

Comment faire correspondre des chaînes avec des expressions régulières Python : 1. Utilisez l'expression régulière [(.+?)] pour extraire la chaîne à une seule position ; 2. Utilisez [(?P…) 】 Cette expression régulière 【correspond aux chaînes dans plusieurs positions consécutives.

Comment faire correspondre une chaîne avec une expression régulière Python

Recommandations d'apprentissage gratuites associées : Tutoriel vidéo Python

Méthode d'expression régulière Python pour faire correspondre les chaînes :

Extraction de chaîne à une seule position

Dans. dans ce cas, nous pouvons utiliser l'expression régulière (.+?) pour extraire. Par exemple, pour une chaîne "a123b", si l'on veut extraire la valeur 123 entre ab, on peut utiliser findall avec une expression régulière, qui renverra une liste contenant toutes les conditions qui correspondent à la situation.

Le code est le suivant :

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

1.1 Correspondance gourmande et non gourmande

Si on a une chaîne "a123b456b", si on veut faire correspondre a et toutes les valeurs entre le dernier b au lieu des valeurs entre a et la première occurrence de b peut être utilisé pour contrôler la correspondance gourmande et non gourmande régulière.

Le code est le suivant :

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 Correspondance multi-lignes

Si vous souhaitez une correspondance multi-lignes, vous devez ajouter re. S et re.M Logo Après avoir ajouté re.S. Correspondra aux caractères de nouvelle ligne, par défaut. Ne correspondra pas aux caractères de nouvelle ligne.

Le code est le suivant :

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')]

Après avoir ajouté re.M, la marque ^$ correspondra à chaque ligne. Par défaut, ^ et $ ne correspondront qu'à la première ligne.

Le code est le suivant :

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

2. Extraction de chaîne de plusieurs positions consécutives

Dans ce cas on peut utiliser le (?P8a11bc632ea32a57b3e3693c7987c420…) régulier formule d'expression à extraire. Par exemple, si nous avons une ligne de 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"' et que nous voulons extraire tout le contenu de cette ligne de journal, nous pouvons écrire plusieurs (?P8a11bc632ea32a57b3e3693c7987c420expr) à extraire, où le nom peut être remplacé par la variable à laquelle vous avez nommé la chaîne. cet emplacement, expr peut être changé en extraction. La position peut être régularisée.

Le code est le suivant :

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

Le résultat de sortie est :

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

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn