preg_match_all

(PHP 3 >= 3.0.9, PHP 4, PHP 5)

preg_match_all --  Führt eine umfassende Suche nach Übereinstimmungen mit regulärem Ausdruck durch

Beschreibung

int preg_match_all ( string Suchmuster, string Zeichenkette, array &Treffer [, int Flags [, int Versatz]] )

Durchsucht Zeichenkette nach allen Übereinstimmungen mit dem in Suchmuster angegebenen regulären Ausdruck und legt sie in der durch Flags festgelegten Reihenfolge in Treffer ab.

Nachdem die erste Übereinstimmung gefunden wurde, wird die nachfolgende Suche jeweils am Ende der letzten Übereinstimmung fortgesetzt.

Flags 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 $treffer[0] ein Array von Übereinstimmungen mit dem kompletten Suchmuster ist, $treffer[1] ein Array von Zeichenketten, die mit dem ersten eingeklammerten Teil-Suchmuster übereinstimmen und so weiter.

<?php
preg_match_all
("|<[^>]+>(.*)</[^>]+>|U",
    
"<b>Beispiel: </b><div align=left>das ist ein Test</div>",
    
$ausgabe, PREG_PATTERN_ORDER);
echo
$ausgabe[0][0] . ", " . $ausgabe[0][1] . "\n";
echo
$ausgabe[1][0] . ", " . $ausgabe[1][1] . "\n";
?>

Dieses Beispiel erzeugt:

<b>Beispiel: </b>, <div align=left>das ist ein Test</div>
Beispiel: , das ist ein Test

Also enthält $ausgabe[0] ein Array von Zeichenketten, die mit dem kompletten Suchmuster übereinstimmen und $ausgabe[1] ein Array von Zeichenketten, die sich zwischen Tags befinden.

PREG_SET_ORDER

Ordnet die Ergebnisse so an, dass $treffer[0] ein Array aus dem ersten Satz von Übereinstimmungen ist, $treffer[1] ein Array aus dem zweiten Satz von Übereinstimmungen und so weiter.

<?php
preg_match_all
("|<[^>]+>(.*)</[^>]+>|U",
    
"<b>Beispiel: </b><div align=\"left\">das ist ein Test</div>",
    
$ausgabe, PREG_SET_ORDER);
echo
$ausgabe[0][0] . ", " . $out[0][1] . "\n";
echo
$ausgabe[1][0] . ", " . $out[1][1] . "\n";
?>

Dieses Beispiel erzeugt:

<b>Beispiel: </b>, Beispiel: 
<div align="left">das ist ein Test</div>, das ist ein Test

In diesem Fall ist $treffer[0] der erste Satz von Übereinstimmungen und $treffer[0][0] enthält den Text, der mit dem kompletten Suchmuster übereinstimmt, $treffer[0][1] den Text, der mit dem ersten Teil-Suchmuster übereinstimmt und so weiter. Auf die gleiche Weise ist $treffer[1] der zweite Satz von Übereinstimmungen etc.

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 die Rückgabewerte in einem Array dahingehend ändert, dass jedes Element ein Array ist, das aus der übereinstimmenden Zeichenkette als Element 0 und deren Stelle in der durchsuchten Zeichenkette als Element 1 besteht. Dieses Flag steht seit PHP 4.3.0 zur Verfügung.

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 Versatz kann verwendet werden, um eine andere Stelle anzugeben, ab der gesucht werden soll. Der Parameter Versatz steht seit PHP 4.3.3 zur Verfügung.

Anmerkung: Die Verwendung von Versatz entspricht nicht der Übergabe von substr($zeichenkette, $versatz) an Stelle der Zeichenkette an preg_match_all(), weil Suchmuster Angaben wie zum Beispiel ^, $ oder (?<=x) enthalten kann. Für Beispiele siehe preg_match().

Gibt die Anzahl der Übereinstimmungen mit dem kompletten Suchmuster zurück (die auch Null sein kann) oder FALSE, falls ein Fehler auftrat.

Beispiel 1. Alle Telefonnummern aus einem Text holen.

<?php
preg_match_all
("/\(?  (\d{3})?  \)?  (?(1)  [\-\s] ) \d{3}-\d{4}/x",
                
"Wählen Sie 555-1212 oder 1-800-555-1212", $telefon);
?>

Beispiel 2. Zusammen gehörende HTML-Tags finden (gierig)

<?php
// Das \\2 ist ein Beispiel für Rückreferenzierung. Es teilt pcre mit, dass
// der reguläre Ausdruck mit dem für das zweite Klammerpaar, also in diesem
// Fall mit dem für ([\w]+) gefundenen Ausdruck selbst übereinstimmen 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);

for (
$i=0; $i< count($treffer[0]); $i++) {
  echo
"gefunden: " . $treffer[0][$i] . "\n";
  echo
"Teil 1: " . $treffer[1][$i] . "\n";
  echo
"Teil 2: " . $treffer[3][$i] . "\n";
  echo
"Teil 3: " . $treffer[4][$i] . "\n\n";
}
?>

Dieses Beispiel erzeugt:

gefunden: <b>fett gedruckter Text</b>
Teil 1: <b>
Teil 2: fett gedruckter Text
Teil 3: </b>

gefunden: <a href=howdy.html>klick mich an</a>
Teil 1: <a href=howdy.html>
Teil 2: klick mich an
Teil 3: </a>

Siehe auch preg_match(), preg_replace() und preg_split().

Hosting by: Hurra Communications GmbH
Generated: 2007-01-26 17:57:07