Angenommen, Sie müssen alle Vorkommen eines Musters in einer Zeichenfolge finden, auch wenn diese Vorkommen einander überlappen. Anhand der Zeichenfolge „nnnn“ möchten Sie beispielsweise die folgenden Übereinstimmungen identifizieren:
<code>nn nnn nnn</code>
Obwohl reguläre Ausdrücke nicht von Natur aus für diese Art des Überlappungsabgleichs konzipiert sind, gibt es einige mögliche Lösungen:
Ein Ansatz besteht darin, Forward-Lookbehind-Behauptungen zu verwenden, die als (?<=...) bezeichnet werden
Eine direktere und intuitivere Methode ist die Verwendung der Forward-Lookahead-Behauptung: (?=nn)n. Dieses Muster sucht nach dem Vorhandensein von „nn“ nach den aktuellen „n“ Zeichen, was zu einer Übereinstimmung am Anfang jeder „nn“-Sequenz führt.
Ein anderer Ansatz besteht darin, Forward-Lookahead mit einfangenden Klammern zu kombinieren: (n)(?=(n)). Diese Formel erfasst das erste „n“ in Gruppe (1) und das zweite „n“ in Gruppe (2) und bietet so eine größere Flexibilität beim Abgleich komplexer Muster.
Mit diesen Techniken können Sie effizient überlappende Übereinstimmungen in regulären Ausdrucksmustern finden, auch wenn diese vom üblichen Zweck regulärer Ausdrücke abweichen.
Das obige ist der detaillierte Inhalt vonWie kann ich überlappende Regex-Übereinstimmungen in einem String finden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!