Erweiterte Verwendung regulärer Ausdrücke in Python

巴扎黑
Freigeben: 2017-03-30 14:15:22
Original
1858 Leute haben es durchsucht

Für Python erfordert das Erlernen der Regelmäßigkeit das Erlernen der Verwendung des Moduls re. In diesem Artikel werden einige fortgeschrittene Techniken vorgestellt, die jeder beherrschen sollte.

Reguläres Ausdrucksobjekt kompilieren

Die re.compile-Funktion generiert ein reguläres Ausdrucksobjekt basierend auf einer Musterzeichenfolge und optionalen Flag-Parametern. Dieses Objekt verfügt über eine Reihe von Methoden zum Abgleichen und Ersetzen regulärer Ausdrücke. Es gibt geringfügige Unterschiede in der Verwendung. Um beispielsweise eine Zeichenfolge abzugleichen, können Sie die folgende Methode verwenden:

Wenn Sie „compilieren“ verwenden, wird daraus:

Warum müssen Sie es verwenden? so was? Tatsächlich werden reguläre Ausdrucksobjekte wiederverwendet, um die Geschwindigkeit des Abgleichs regulärer Ausdrücke zu verbessern. Vergleichen wir die Effizienz der beiden Methoden:

Erweiterte Verwendung regulärer Ausdrücke in Python

Sie sehen, dass die zweite Methode viel schneller ist. Bei der tatsächlichen Arbeit werden Sie feststellen, dass der Effekt umso besser ist, je mehr Sie kompilierte Objekte mit regulären Ausdrücken verwenden.

Gruppieren

Möglicherweise haben Sie die Verwendung der Gruppierung übereinstimmender Inhalte gesehen:

Erweiterte Verwendung regulärer Ausdrücke in Python

Durch Hinzufügen von Klammern zum Mit den abzugleichenden Objekten können Sie die Übereinstimmungsergebnisse genau abgleichen. Wir können auch eine verschachtelte Gruppierung durchführen:

Erweiterte Verwendung regulärer Ausdrücke in Python

Gruppierung kann die Anforderungen erfüllen, aber manchmal ist die Lesbarkeit schlecht, dann kann die Gruppierung benannt werden:

Erweiterte Verwendung regulärer Ausdrücke in Python

Jetzt ist die Lesbarkeit sehr hoch.

String-Matching

Schüler, die sed gelernt haben, haben möglicherweise die folgende Ersetzungsverwendung gesehen:

Diese 1 stellt das Ergebnis des vorherigen regulären Matchs dar. Der obige Sed dient dazu, den übereinstimmenden Ergebnissen eckige Klammern hinzuzufügen.

hat auch diese Verwendung im re-Modul:

Erweiterte Verwendung regulärer Ausdrücke in Python

Es ist auch möglich, benannte Gruppierung zu verwenden:

Erweiterte Verwendung regulärer Ausdrücke in Python

Schauen Sie sich um

Das Modul unterstützt auch Nearest Matching, schauen Sie sich einfach das Beispiel an:

Erweiterte Verwendung regulärer Ausdrücke in Python

Verwenden Sie die Funktion

beim regulären Matching Das meiste, was wir zuvor gesehen haben, ist das Matching eines Ausdrucks, aber manchmal sind die Anforderungen viel komplexer, insbesondere beim Ersetzen.

Zum Beispiel können Chat-Datensätze über die Slack-API abgerufen werden, wie zum Beispiel der folgende Satz:

Unter ihnen sind <@U1EAT8MG9> und <@U0K1MF23Z> Bei Slack müssen Sie diese Korrespondenz über andere Schnittstellen abrufen.

Das Ergebnis sieht ähnlich aus:

Nach dem Parsen der Korrespondenz hoffe ich auch, dass die spitzen Klammern entfernt werden nach der Ersetzung steht „@xiaoming, @laolin Ja, das ist tatsächlich so“

Wie kann man das mit regulären Ausdrücken erreichen?

Erweiterte Verwendung regulärer Ausdrücke in Python

Muster kann also natürlich auch eine Funktion sein

Das obige ist der detaillierte Inhalt vonErweiterte Verwendung regulärer Ausdrücke in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage