Beschreibung:
int preg_match ( string $pattern , string $subject [, array &$matches [, int $flags = 0 [, int $offset = 0 ]]] )
Durchsucht subject nach Übereinstimmungen mit dem in pattern angegebenen regulären Ausdruck.
Parameter-Liste:
pattern
Der Ausdruck, nach dem gesucht werden soll, als Zeichenkette.
subject
Die zu durchsuchende Zeichenkette.
matches
Falls der Parameter matches angegeben wurde, wird er mit den Suchergebnissen gefüllt. $matches[0] enthält dann den Text, der auf das komplette Suchmuster passt, $matches[1] den Text, der
auf das erste eingeklammerte Teilsuchmuster passt und so weiter.
flags
flags kann das folgende Flag sein:
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.
offset
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($subject, $offset) an Stelle der zu Zeichenkette an preg_match(), weil pattern Angaben wie zum
Beispiel ^, $ oder (?<=x) enthalten kann. Vergleiche:
<?php
$zeichenkette = "abcdef";
$suchmuster = '/^def/';
preg_match($suchmuster, $zeichenkette, $treffer, PREG_OFFSET_CAPTURE, 3);
print_r($treffer);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
Array
(
)
während dieses Beispiel
<?php
$zeichenkette = "abcdef";
$suchmuster = '/^def/';
preg_match($suchmuster, substr($zeichenkette,3), $treffer, PREG_OFFSET_CAPTURE);
print_r($treffer);
?>
folgende Ausgabe erzeugt
Array
(
[0] => Array
(
[0] => def
[1] => 0
)
)
Rückgabewerte:
preg_match() gibt 1 zurück, falls eine Übereinstimmung zwischen pattern und subject gefunden wurde, 0, falls nicht oder FALSE, falls ein Fehler auftrat.
Warnung
Diese Funktion kann sowohl das boolsche FALSE zurückliefern, als auch einen nicht-boolschen Wert, welcher zu FALSE ausgewertet wird. Weitere Informationen entnehmen Sie bitte
dem Abschnitt über die boolschen Typen. Benutzen Sie deshalb den === Operator, um den Rückgabewert dieser Funktion zu überprüfen.
Changelog
Version Beschreibung
5.3.6 Gibt FALSE zurück, wenn offset größer als die Länge von subject ist.
5.2.2 Benannte Teilsuchmuster akzeptieren nun sowohl die Syntaxen (?<name>) und (?'name') als auch (?P<name>). Vorherige Versionen akzeptierten nur (?P<name>).
Beispiele
Beispiel #1 Die Zeichenkette "php" finden
<?php
// Das "i" nach der Suchmuster-Begrenzung kennzeichnet eine Suche ohne
// Berücksichtigung von Groß- und Kleinschreibung
if (preg_match("/php/i", "PHP ist die Web-Scripting-Sprache der Wahl.")) {
echo "Es wurde eine Übereinstimmung gefunden.";
} else {
echo "Es wurde keine Übereinstimmung gefunden.";
}
?>
Quelle: http://php.net/manual/de/function.preg-match.php
php.net/manual/de/function.preg-match.php
<?php
function db($sql)
{
if ($_SERVER["HTTP_HOST"] == "localhost")
{
/// DB-Adresse XAMPP
$host = "localhost";
$benutzer = "root";
$passwort = "";
$dbname = "Datenbankname";
}
if (preg_match("/http...www.^/", $_SERVER["HTTP_HOST"]))
{
/// DB-Adresse Serverseitig
$host = "Webseitenname";
$benutzer = "Benutzername";
$passwort = "Passwort";
$dbname = "Datenbankname";
}
$link = mysql_connect($host, $benutzer, $passwort);
mysql_select_db($dbname, $link);
$ergebnis = mysql_query($sql, $link) or die(mysql_error($link)."<br />$sql");
// Gespeicherte Datensatz-ID
if (preg_match("/INSERT/", $sql))
{
$uid = mysql_insert_id();
mysql_close($link);
return $uid;
}
else // Normalfall
{
mysql_close($link);
return $ergebnis;
}
}
?>