Heim  >  Artikel  >  Backend-Entwicklung  >  Ausführliche Erklärung regulärer Ausdrücke in PHP (Codebeispiele)

Ausführliche Erklärung regulärer Ausdrücke in PHP (Codebeispiele)

易达
易达Original
2020-05-29 21:32:102920Durchsuche

Ziele dieses Artikels:

1. Definition regulärer Ausdrücke

2. Mehrere grundlegende Syntax regulärer Ausdrücke

(1) Definition regulärer Ausdrücke

Regulärer Ausdruck ist eine logische Formel, die mit Zeichenfolgen arbeitet und bestimmte Zeichen zu einer regulären Zeichenfolge kombiniert.

Zum Beispiel:

<?php
$p = &#39;/abc123/&#39;;
$str = "abc123bbbb";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则&#39;;
}
?>

Der obige Code „/abc123/“ in ist ein regulärer Ausdruck. Daraus können wir ersehen, dass /abc123/ eine Zeichenfolge ist, die aus Zeichen und Zahlen besteht, aber diese Zeichen haben ihre eigene spezielle Bedeutung, wie z. B. /abc123/. Die Regel dieses regulären Ausdrucks ist, dass die Zeichenfolge mit beginnt abc123. Jede Zeichenfolge, die dieser Regel entspricht, passt zu diesem Ausdruck

(2) Mehrere grundlegende Syntaxen von regulären Ausdrücken

1 Das reguläre Übereinstimmungsmuster verwendet Trennzeichen und Metazeichen Dabei kann es sich um ein beliebiges Zeichen außer Zahlen, Backslashes und Leerzeichen handeln. Gängige Trennzeichen wie Schrägstrich (/), Raute-Symbol (#) und Negationssymbol (~)

Zum Beispiel:

/hello world/ Die Bedeutung des Ausdrucks Ja: Die Zeichenfolge beginnt mit hello world
#^[0-9]$# Der Ausdruck bedeutet: Passen Sie die Zahlen 0-9 an
~hello~ Der Ausdruck bedeutet: Die Zeichenfolge enthält hello

Testen wir es mit Code

Beispiel 1,

/hello world/ Der Ausdruck bedeutet: Die Zeichenfolge beginnt mit hello world

<?php
$p = "/hello world/";
$str = "hello world,i am a student";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则/hello world/<br/>&#39;;
}

?>

Das laufende Ergebnis ist wie folgt:

Die Zeichenfolge entspricht dieser Regel/Hallo Welt/

Ändern Sie die Zeichenfolge, um zu sehen, dass das laufende Ergebnis unten zu sehen ist Beginnen Sie nicht mit „Hallo Welt“

<?php
$p = "/hello world/";
$str = "helloworld,i am a student";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则/hello world/<br/>&#39;;
}

?>

:

Blank

Beispiel 2,

#^[0-9]$# Die Bedeutung des Ausdrucks ist: Übereinstimmung mit den Zahlen 0-9

<?php
$p2 = "#^[0-9]$#";
$str2 = "3";
if (preg_match($p2, $str2)) {
    echo &#39;该字符串符合这个规则"#^[0-9]$#<br/>&#39;;
}
?>

Das laufende Ergebnis ist:

Die Zeichenfolge entspricht zu dieser Regel „#^[0-9]$#

Ändern Sie den Code, ändern Sie die Zeichenfolge in eine Zahl größer als 9 und sehen Sie

<?php
$p2 = "#^[0-9]$#";
$str2 = "30";
if (preg_match($p2, $str2)) {
    echo &#39;该字符串符合这个规则"#^[0-9]$#<br/>&#39;;
}else{
    echo &#39;该字符串不符合这个规则"#^[0-9]$#<br/>&#39;;
}
?>

run Das Ergebnis lautet:

Diese Zeichenfolge entspricht nicht dieser Regel"#^[0-9]$#

Beispiel 3,

~hello~ Die Bedeutung des Ausdrucks ist: Die Zeichenfolge enthält hallo

Der spezifische Code lautet wie folgt:

<?php
$p3 = "~hello~";
$str3 = "ahellobb";
if (preg_match($p3, $str3)) {
    echo &#39;该字符串符合这个规则:~hello~&#39;;
}else{
    echo &#39;该字符串不符合这个规则:~hello~&#39;;
}
?>

Das laufende Ergebnis ist:

Die Zeichenfolge entspricht dieser Regel: ~hello~

Ändern Sie nun die Testzeichenfolge so, dass sie kein Hallo enthält

Der spezifische Code lautet wie folgt:

<?php
$p3 = "~hello~";
$str3 = "hell o";
if (preg_match($p3, $str3)) {
    echo &#39;该字符串符合这个规则:~hello~&#39;;
}else{
    echo &#39;该字符串不符合这个规则:~hello~&#39;;
}
?>

Das laufende Ergebnis ist:

Diese Zeichenfolge entspricht nicht dieser Regel: ~hello~

Es ist ersichtlich, dass:

1, / bedeutet der Anfang

2 , ^ bedeutet, mit dem Zeichen nach ^ zu beginnen

3 $ bedeutet, mit dem Zeichen vor $ zu enden

4 ~ bedeutet, das zu enthalten Bedeutung

2. Wenn das Muster Trennzeichen enthält, müssen die Trennzeichen mit einem Backslash () maskiert werden.

Zum Beispiel:

/https://www./ bedeutet, dass es mit https://www beginnt.

Das Spezifische Der Code lautet wie folgt:

<?php
$p = "/https:\/\/www./";
$str = "https://www.baidu.com";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则:/https:\/\/www./&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/https:\/\/www./&#39;;
}

Das laufende Ergebnis ist:

Die Zeichenfolge entspricht dieser Regel: /https://www./

Versuchen Sie, die Zeichenfolge zu ändern. Wenn sie nicht mit https://www. beginnt, sehen Sie sich

<?php
$p = "/https:\/\/www./";
$str = "http://www.baidu.com";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则:/https:\/\/www./&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/https:\/\/www./&#39;;
}

an. Das Ergebnis ist:

Diese Zeichenfolge funktioniert Diese Regel nicht einhalten: /https:/ /www./

3 Wenn das Muster viele Trennzeichen enthält, wird empfohlen, andere Zeichen als Trennzeichen zu verwenden, oder Sie kann preg_quote zum Escape verwenden.

Beispiel 1,

<?php

$p = "/https://www.baidu.com/a/b/index.html/";
$str = "http://www.baidu.com/a/b/index.html";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则:/https://www.baidu.com/a/b/index.html/&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/https://www.baidu.com/a/b/index.html/&#39;;
}

Das laufende Ergebnis ist:

Warnung: preg_match(): Unbekannter Modifikator '/' in D:E-classclass-codeclassingindex.php in Zeile 7
Diese Zeichenfolge entspricht nicht dieser Regel:/https://www.baidu.com/a/b/index.html/

Sie können zu diesem Zeitpunkt also nicht direkt schreiben/entweder wie oben beschrieben entkommen oder wie folgt vorgehen

Der spezifische Code lautet wie folgt:

<?php
$p = "https://www.baidu.com/a/b/index.html";
$p = &#39;/&#39;.preg_quote($p, &#39;/&#39;).&#39;/&#39;;
$str = "https://www.baidu.com/a/b/index.html";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则:/https://www.baidu.com/a/b/index.html/&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/https://www.baidu.com/a/b/index.html/&#39;;
}
?>

Das laufende Ergebnis ist:

Diese Zeichenfolge entspricht dieser Regel: /https://www.baidu.com/a/b/index.html/

4 Verwenden Sie es nach dem Trennzeichen. Mustermodifikatoren umfassen: i, m, s usw.

Zusammenfassung:

1. i bedeutet, dass die Groß- und Kleinschreibung ignoriert werden kann

2. m bedeutet mehrzeilige Übereinstimmung

3. Wenn dieser Modifikator festgelegt ist, stimmt das Punkt-Metazeichen (.) im Muster mit allen Zeichen überein, einschließlich Zeilenumbruchzeichen. Ohne diese Einstellung werden keine Zeilenumbrüche berücksichtigt.

Fall 1.

Praktische Ziele:

1. i bedeutet, dass dieser Fall ignoriert werden kann

<?php
$p = "/ABc/i";
$str = "abc";
if (preg_match($p, $str)) {
    echo &#39;该字符串符合这个规则:/ABc/i&#39;;
}else{
    echo &#39;该字符串不符合这个规则:/ABc/i&#39;;
}
?>

Das laufende Ergebnis ist :

Diese Zeichenfolge entspricht dieser Regel: /ABc/i

Fall 2,

Praktisches Ziel :

1. m bedeutet mehrzeiliges Matching

Der spezifische Code lautet wie folgt:

<?php
$p = "/chinese/m";
$str = "i am a chinese people,\n you alose is a chinese people";
$math = "";
if (preg_match_all($p, $str,$math)) {
    echo &#39;该字符串符合这个规则:/chinese/m,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则:/chinese/m&#39;;
}
?>

Das laufende Ergebnis ist:

Dies Zeichenfolge entspricht dieser Regel: / chinese/m, das passende Ergebnis ist: Array ( [0] => Array ( [0] => chinese [1] => chinese ) )

Hier ist zu beachten, dass Sie preg_match_all verwenden, andernfalls wird mit preg_match nur eine Zeile abgeglichen

接下来我们运行下效果

<?php
$p = "/chinese/m";
$str = "i am a chinese people,\n you alose is a chinese people";
$math = "";
if (preg_match($p, $str,$math)) {
    echo &#39;该字符串符合这个规则:/chinese/m,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则:/chinese/m&#39;;
}
?>

运行结果为:

该字符串符合这个规则:/chinese/m,匹配结果为:Array ( [0] => chinese )

其实/m在此也算多此一举,因为preg_match_all就是表示多行匹配了

<?php
$p = "/chinese/";
$str = "i am a chinese people,\n you alose is a chinese people";
$math = "";
if (preg_match_all($p, $str,$math)) {
    echo &#39;该字符串符合这个规则,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则&#39;;
}

?>

运行结果其实是一样的,结果为:

该字符串符合这个规则,匹配结果为:Array ( [0] => Array ( [0] => chinese [1] => chinese ) )

只是要知道m表示多行匹配的意思

案例三、

实践目标:

1、如果设定了此修正符,模式中的圆点元字符(.)匹配所有的字符,包括换行符。没有此设定的话,则不包括换行符。

具体代码如下:

<?php
$p = "/chinese ./s";
$str = "i am a chinese \n people, you alose is a chinese good people";
$math = "";
if (preg_match_all($p, $str,$math)) {
    echo &#39;该字符串符合这个规则,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则&#39;;
}
?>

运行结果如下:

该字符串符合这个规则,匹配结果为:Array ( [0] => Array ( [0] => chinese [1] => chinese g ) )

说明第一个chinese 后面的字符是换行也匹配到了,这说明了s的意思就是.要包含换行符,接下来

我们去掉s,看下最终的结果

<?php
$p = "/chinese ./";
$str = "i am a chinese \n people, you alose is a chinese good people";
$math = "";
if (preg_match_all($p, $str,$math)) {
    echo &#39;该字符串符合这个规则,匹配结果为:&#39;;
    print_r($math);
}else{
    echo &#39;该字符串不符合这个规则&#39;;
}
?>

运行结果如下:

该字符串符合这个规则,匹配结果为:Array ( [0] => Array ( [0] => chinese g ) )

说明此刻只匹配到一个了,因为.不包含换行符,所以第一个chinese没有匹配到

总结:

本文主要讲解了

1、正则表达式的定义

2、正则表达式的几个基本语法

Das obige ist der detaillierte Inhalt vonAusführliche Erklärung regulärer Ausdrücke in PHP (Codebeispiele). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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