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<name>…) 】 Cette expression régulière 【correspond aux chaînes dans plusieurs positions consécutives.
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 (?P<name>…)
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 (?P<name>expr)
à 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('^(?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
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!