PHP
Referenzliste
preg_match_all
PCRE-Funktionen
Befehl:
int preg_match_all ( string $pattern , string $subject [, array &$matches [, int $flags = PREG_PATTERN_ORDER [, int $offset = 0 ]]] )
Parameter-Liste:
Beschreibung | |
---|---|
Der Ausdruck, nach dem gesucht werden soll, als Zeichenkette. | |
Die zu durchsuchende Zeichenkette. | |
Ein mehrdimensionales Array mit allen gefundenen Übereinstimmungen, das den flags entsprechend sortiert ist. | |
Kann eine Kombination folgender Flags sein (beachten Sie, dass es keinen Sinn hat, PREG_PATTERN_ORDER zusammen mit PREG_SET_ORDER zu verwenden):PREG_PATTERN_ORDER Ordnet die Ergebnisse so an, dass $matches[0] ein Array von Übereinstimmungen mit dem kompletten Suchmuster ist, $matches[1] ein Array von Zeichenketten, die auf das erste eingeklammerte Teilsuchmuster passen und so weiter. <?php Das oben gezeigte Beispiel erzeugt folgende Ausgabe: <b>Beispiel: </b>, <div align=left>das ist ein Test</div> PREG_SET_ORDER Ordnet die Ergebnisse so an, dass $matches[0] ein Array aus dem ersten Satz von Übereinstimmungen ist, $matches[1] ein Array aus dem zweiten Satz von Übereinstimmungen und so weiter. <?php Das oben gezeigte Beispiel erzeugt folgende Ausgabe: <b>Beispiel: </b>, Beispiel: PREG_OFFSET_CAPTURE Wenn dieses Flag gesetzt ist, wird mit jeder gefundenen Übereinstimmung der dazugehörige Versatz in der Zeichenkette zurückgegeben. Beachten Sie, dass dies den Wert von matches in ein Array ändert, in dem jedes Element ein Array ist, das aus der übereinstimmenden Zeichenkette als Element 0 und deren Stelle in subject als Element 1 besteht.Falls kein Flag für die Anordnung angegeben wurde, wird PREG_PATTERN_ORDER angenommen. | |
Normalerweise beginnt die Suche am Anfang der Zeichenkette. Der optionale Parameter offset kann verwendet werden, um eine andere Stelle in Bytes anzugeben, ab der gesucht werden soll.Hinweis: Die Verwendung von offset entspricht nicht der Übergabe von substr($zeichenkette, $versatz) an Stelle der Zeichenkette an preg_match_all(), weil pattern Angaben wie zum Beispiel ^, $ oder (?<=x) enthalten kann. Für Beispiele siehe preg_match(). |
Rückgabewerte:
Gibt die Anzahl der Übereinstimmungen mit dem kompletten Suchmuster zurück (die auch Null sein kann) oder
FALSE
, falls ein Fehler auftrat. Beschreibung:
Durchsucht
Nachdem die erste Übereinstimmung gefunden wurde, wird die nachfolgende Suche jeweils am Ende der letzten Übereinstimmung fortgesetzt.
subject
nach allen Übereinstimmungen mit dem in pattern
angegebenen regulären Ausdruck und legt sie in der durch flags
festgelegten Reihenfolge in matches
ab.Nachdem die erste Übereinstimmung gefunden wurde, wird die nachfolgende Suche jeweils am Ende der letzten Übereinstimmung fortgesetzt.
Aktiv in Version:
(PHP 4, PHP 5, PHP 7)
Siehe auch:
Führt eine Suche mit einem regulären Ausdruck durch
Sucht und ersetzt mit regulären Ausdrücken
Zerlegt eine Zeichenkette anhand eines regulären Ausdrucks
Liefert den Fehlercode der letzten PCRE RegEx-Auswertung
preg_match_all() - Beispiel: Alle Telefonnummern aus einem Text holen.
Eingabe:
<?PHP preg_match_all("/\(? (\d{3})? \)? (?(1) [\-\s] ) \d{3}-\d{4}/x", "Wählen Sie 555-1212 oder 1-800-555-1212", $telefon); ?>
Beschreibung:
Beschreibung | |
---|---|
5.4.0 | Der Parameter matches ist nun optional. |
5.3.6 | Gibt FALSE zurück, wenn offset grösser als die Länge von subject ist. |
5.2.2 | Benannte Teilsuchmuster (named subpatterns) akzeptieren nun die Syntaxen (?<name>) und (?'name') sowie (?P<name>). Vorherige Versionen akzeptierten nur (?P<name>). |
4.3.3 | Den Parameter offset hinzugefügt |
4.3.0 | Das Flag PREG_OFFSET_CAPTURE hinzugefügt. |
preg_match_all() - Beispiel 2: Zusammengehörende HTML-Tags finden (gierig)
Eingabe:
<?PHP // Das \\2 ist ein Beispiel für Rückreferenzierung. Es teilt pcre mit, dass // der reguläre Ausdruck auf den für das zweite Klammerpaar gefundenen // Ausdruck selbst, also in diesem Fall auf den für ([\w]+) gefundenen // Ausdruck passen muss. // Der zusätzliche Backslash wird wegen der doppelten Anführungsstriche // benötigt. $html = "<b>fett gedruckter Text</b><a href=howdy.html>klick mich an</a>"; preg_match_all("/(<([\w]+)[^>]*>)(.*?)(<\/\\2>)/", $html, $treffer, PREG_SET_ORDER); foreach ($treffer as $wert) { echo "gefunden: " . $wert[0] . "\n"; echo "Teil 1: " . $wert[1] . "\n"; echo "Teil 2: " . $wert[2] . "\n"; echo "Teil 3: " . $wert[3] . "\n"; echo "Teil 4: " . $wert[4] . "\n\n"; } ?>
Ausgabe:
gefunden: <b>fett gedruckter Text</b>
Teil 1: <b>
Teil 2: b
Teil 3: fett gedruckter Text
Teil 4: </b>
gefunden: <a href=howdy.html>klick mich an</a>
Teil 1: <a href=howdy.html>
Teil 2: a
Teil 3: klick mich an
Teil 4: </a>
Teil 1: <b>
Teil 2: b
Teil 3: fett gedruckter Text
Teil 4: </b>
gefunden: <a href=howdy.html>klick mich an</a>
Teil 1: <a href=howdy.html>
Teil 2: a
Teil 3: klick mich an
Teil 4: </a>
Beschreibung:
Beschreibung | |
---|---|
5.4.0 | Der Parameter matches ist nun optional. |
5.3.6 | Gibt FALSE zurück, wenn offset grösser als die Länge von subject ist. |
5.2.2 | Benannte Teilsuchmuster (named subpatterns) akzeptieren nun die Syntaxen (?<name>) und (?'name') sowie (?P<name>). Vorherige Versionen akzeptierten nur (?P<name>). |
4.3.3 | Den Parameter offset hinzugefügt |
4.3.0 | Das Flag PREG_OFFSET_CAPTURE hinzugefügt. |
preg_match_all() - Beispiel 3: Benannte Teilsuchmuster (named subpatterns)
Eingabe:
<?PHP $str = <<<FOO a: 1 b: 2 c: 3 FOO; preg_match_all('/(?P<name>\w+): (?P<zahl>\d+)/', $str, $treffer); /* Folgendes funktioniert ab PHP 5.2.2 (PCRE 7.0) ebenfalls, für die * Rückwärtskompatibilität wird aber die vorherige Form empfohlen. */ // preg_match_all('/(?<name>\w+): (?<zahl>\d+)/', $str, $treffer); print_r($treffer); ?>
Ausgabe:
Array
(
[0] => Array
(
[0] => a: 1
[1] => b: 2
[2] => c: 3
)
[name] => Array
(
[0] => a
[1] => b
[2] => c
)
[1] => Array
(
[0] => a
[1] => b
[2] => c
)
[zahl] => Array
(
[0] => 1
[1] => 2
[2] => 3
)
[2] => Array
(
[0] => 1
[1] => 2
[2] => 3
)
)
(
[0] => Array
(
[0] => a: 1
[1] => b: 2
[2] => c: 3
)
[name] => Array
(
[0] => a
[1] => b
[2] => c
)
[1] => Array
(
[0] => a
[1] => b
[2] => c
)
[zahl] => Array
(
[0] => 1
[1] => 2
[2] => 3
)
[2] => Array
(
[0] => 1
[1] => 2
[2] => 3
)
)
Beschreibung:
Beschreibung | |
---|---|
5.4.0 | Der Parameter matches ist nun optional. |
5.3.6 | Gibt FALSE zurück, wenn offset grösser als die Länge von subject ist. |
5.2.2 | Benannte Teilsuchmuster (named subpatterns) akzeptieren nun die Syntaxen (?<name>) und (?'name') sowie (?P<name>). Vorherige Versionen akzeptierten nur (?P<name>). |
4.3.3 | Den Parameter offset hinzugefügt |
4.3.0 | Das Flag PREG_OFFSET_CAPTURE hinzugefügt. |
PCRE-Funktionen