Heim >Backend-Entwicklung >PHP-Problem >So implementieren Sie regelmäßige Ersatzinhalte in PHP
So implementieren Sie die regelmäßige Inhaltsersetzung in PHP: Erstellen Sie zunächst eine PHP-Beispieldatei. Definieren Sie dann eine Reihe von Zeichenfolgen. ) „Regulärer Ausdruck kann den Inhalt ersetzen.
Die Betriebsumgebung dieses Artikels: Windows 7-System, PHP Version 7.1, Dell G3-Computer.
PHP-Funktion preg_replace() regulärer Ersatz aller qualifizierten Zeichenfolgen
PHP preg_replace() regulärer Ersatz, anders als der reguläre JavaScript-Ersatz, PHP preg_replace() Standard ist, alle Symbole zu ersetzen, die dem Element „Bedingungen“ entsprechen .
preg_replace (正则表达式, 替换成, 字符串, 最大替换次数【默认-1,无数次】, 替换次数)
Reguläre Ausdrücke sind in den meisten Sprachen ähnlich, es gibt jedoch auch subtile Unterschiede.
PHP Reguläre Ausdrücke
Normale Zeichen | Reguläre Interpretation |
---|---|
Markieren Sie das nächste Zeichen als Sonderzeichen, wörtliches Zeichen, Rückwärtsreferenz oder oktales Escape-Zeichen. Beispielsweise entspricht „n“ dem Zeichen „n“. „\n“ entspricht einem Zeilenumbruchzeichen. Die Sequenz „\“ entspricht „“ und „(“ entspricht „(“. | |
^ | entspricht dem Anfang der Eingabezeichenfolge. Wenn die Multiline-Eigenschaft des RegExp-Objekts festgelegt ist, entspricht ^ auch „n“ oder „r“ nach „. |
$ | entspricht dem Ende der Eingabezeichenfolge. Wenn die Multiline-Eigenschaft des RegExp-Objekts festgelegt ist, entspricht $ auch der Position vor „n“ oder „r“. |
* | Entspricht dem vorhergehenden Unterausdruck null oder mehrmals, und „zoo“ entspricht {0,} . Beispielsweise kann „zo+“ mit „zo“ und „zoo“ übereinstimmen, aber nicht „z“. + entspricht nullmal dem vorherigen Unterausdruck oder „Once“. )? 2}“ kann nicht mit dem „o“ in „Bob“ übereinstimmen, aber es kann mit zwei o in „food“ übereinstimmen |
{n,} | n. Ist eine nicht negative ganze Zahl. Entspricht mindestens n-mal. Für Beispiel: „o{2,}“ kann nicht mit „o“ in „Bob“ übereinstimmen, aber es kann mit allen „o{1,}“ in „foooood“ übereinstimmen. Entspricht „o+“ „o{0,}“. äquivalent zu „o*“. 3}“ stimmt mit den ersten drei o in „fooooood“ überein. Beachten Sie, dass „o?“ zwischen den beiden Zahlen kein Leerzeichen stehen darf. |
? | Wenn diesem Zeichen ein anderer Begrenzer (*,+) folgt ,?,{n},{n,},{n,m}) Später ist der Abgleichsmodus nicht gierig. Der nicht gierige Modus entspricht so wenig wie möglich von der gesuchten Zeichenfolge, während der standardmäßige gierige Modus mit so wenig übereinstimmt Für die Zeichenfolge „oooo“ wird beispielsweise ein einzelner „o“ gefunden, während „o+“ mit allen „o“-Zeichen übereinstimmt Entspricht jedem einzelnen Zeichen außer „n“. Um ein beliebiges Zeichen zu finden, verwenden Sie bitte ein Muster wie „[sS]“ und erhalten Sie diese Übereinstimmung Verwenden Sie in JScript aus der generierten Matches-Sammlung das Attribut „(“ oder „)“. stimmt mit dem Muster überein, erhält aber kein passendes Ergebnis, was bedeutet, dass dies nicht der Fall ist. Eine Nicht-Get-Übereinstimmung wird nicht für die spätere Verwendung gespeichert. Dies ist nützlich, wenn Teile eines Musters mit dem oder-Zeichen „(|)“ kombiniert werden. Beispielsweise ist „industr(?:y|ies)“ ein einfacherer Ausdruck als „industry|industries“. |
(?=Muster) | Positive Vorwärtssuche |
(?!Muster) | |
, gleicht die Suchzeichenfolge am Anfang jeder Zeichenfolge ab, die nicht mit dem Muster übereinstimmt. Dies ist eine Nicht-Abruf-Übereinstimmung, d. h. die Übereinstimmung muss nicht zur späteren Verwendung abgerufen werden. Beispielsweise kann „Windows(?!95|98|NT|2000)“ mit „Windows“ in „Windows3.1“ übereinstimmen, aber nicht mit „Windows“ in „Windows2000“. | |
Umgekehrte positive Vorprüfung | , ähnlich der vorwärts gerichteten positiven Vorprüfung, jedoch in die entgegengesetzte Richtung. Beispielsweise kann „(?<=95|98|NT|2000)Windows“ mit „Windows“ in „2000Windows“ übereinstimmen, aber nicht mit „Windows“ in „3.1Windows“. |
(? | Umgekehrte Negativvorschau | x|y | entspricht x oder y. Beispielsweise entspricht „z|food“ „z“ oder „food“. „(z|f)ood“ entspricht „zood“ oder „food“.
[xyz] | |
[^xyz] | Eine Sammlung negativer Zeichen. Entspricht jedem Zeichen, das nicht enthalten ist. Beispielsweise würde „[^abc]“ mit „plin“ in „plain“ übereinstimmen. |
[a-z] | Zeichenbereich. Entspricht jedem Zeichen innerhalb des angegebenen Bereichs. „[a-z]“ entspricht beispielsweise jedem Kleinbuchstaben im Bereich „a“ bis „z“. Hinweis: Nur wenn sich der Bindestrich innerhalb der Zeichengruppe und zwischen zwei Zeichen befindet, kann er den Zeichenbereich darstellen. Wenn er am Anfang der Zeichengruppe steht, kann er nur den Bindestrich selbst darstellen. |
[^a-z ] | Negativzeichenbereich. Entspricht jedem Zeichen, das nicht im angegebenen Bereich liegt. „[^a-z]“ entspricht beispielsweise jedem Zeichen, das nicht im Bereich „a“ bis „z“ liegt. |
b | entspricht einer Wortgrenze, die sich auf die Position zwischen einem Wort und einem Leerzeichen bezieht. Beispielsweise kann „erb“ mit „er“ in „never“ übereinstimmen, aber nicht mit „er“ in „verb“. |
B | entspricht Nicht-Wortgrenzen. „erB“ kann mit dem „er“ in „verb“ übereinstimmen, aber nicht mit dem „er“ in „never“. |
cx | entspricht dem durch x angegebenen Steuerzeichen. Beispielsweise entspricht cM einem Strg-M- oder Wagenrücklaufzeichen. Der Wert von x muss A-Z oder a-z sein. Andernfalls behandeln Sie c als wörtliches „c“-Zeichen. |
d | entspricht einem numerischen Zeichen. Entspricht [0-9]. |
D | entspricht einem nicht numerischen Zeichen. Entspricht [^0-9]. |
f | entspricht einem Formular-Feed. Entspricht x0c und cL. |
n | entspricht einem Zeilenumbruchzeichen. Entspricht x0a und cJ. |
r | entspricht einem Wagenrücklaufzeichen. Entspricht x0d und cM. |
s | entspricht allen Leerzeichen, einschließlich Leerzeichen, Zeilenumbrüchen, Tabulatoren, Formularvorschüben, chinesischen Leerzeichen in voller Breite usw. Entspricht [frntv]. |
S | entspricht jedem Zeichen, das kein Leerzeichen ist. Entspricht [^ frntv]. |
t | entspricht einem Tabulatorzeichen. Entspricht x09 und cI. |
v | entspricht einem vertikalen Tabulatorzeichen. Entspricht x0b und cK. |
w | entspricht jedem Wortzeichen, einschließlich des Unterstrichs. Entspricht „[A-Za-z0-9_]“. |
W | entspricht jedem Nicht-Wort-Zeichen. Entspricht „[^A-Za-z0-9_]“. |
xn | entspricht n, wobei n der hexadezimale Escape-Wert ist. Der hexadezimale Escape-Wert muss genau zwei Ziffern lang sein. Beispielsweise entspricht „x41“ „A“. „x041“ entspricht „x04&1“. Die ASCII-Kodierung kann in regulären Ausdrücken verwendet werden. |
num | stimmt mit num überein, wobei num eine positive Ganzzahl ist. Ein Verweis auf die erhaltene Übereinstimmung. „(.)1“ entspricht beispielsweise zwei aufeinanderfolgenden identischen Zeichen. |
n | Identifiziert einen oktalen Escape-Wert oder eine Rückreferenz. n ist eine Rückwärtsreferenz, wenn vor n mindestens n abgerufene Unterausdrücke stehen. Andernfalls, wenn n eine Oktalzahl (0-7) ist, dann ist n ein oktaler Escape-Wert. |
nm | Identifiziert einen oktalen Escape-Wert oder eine Rückreferenz. Wenn vor nm mindestens nm get-Unterausdrücke stehen, handelt es sich bei nm um eine Rückwärtsreferenz. Wenn vor nm mindestens n steht, dann ist n eine Rückwärtsreferenz, gefolgt vom Literal m. Wenn keine der vorherigen Bedingungen erfüllt ist und n und m beide Oktalzahlen (0-7) sind, stimmt nm mit dem oktalen Escape-Wert nm überein. |
nml | Wenn n eine Oktalziffer (0-7) ist und m und l beide Oktalziffern (0-7) sind, dann entspricht dies dem oktalen Escape-Wert nml. |
un | stimmt mit n überein, wobei n ein Unicode-Zeichen ist, das durch vier Hexadezimalziffern dargestellt wird. Beispielsweise entspricht u00A9 dem Copyright-Symbol (©). |
上表是正则表达式比较全面的解释,而商标中的正则字符都有特殊含义,已经不再代表原字符含义。如正则表达式中“+”不代表加号,而是代表匹配一次或多次。而如果想要让“+”表示加号,则需要在其前面加上“\”转义,也就是用“\+”表示加号。
【推荐学习:《PHP视频教程》】
1+1=2 正则表达式是: 1\+1=2
而正则表达式 1+1=2 可以代表,多个1=2,即:
11=2 正则表达式:1+1=2
111=2 正则表达式:1+1=2
1111=2 正则表达式:1+1=2
……
也就是说所有正则字符都有特定含义,如果需要再用来表示原字符含义,就需要在前面加“\”转义,即使非正则字符,用“\”转义也是没有问题的。
1+1=2 正则表达式也可以是: \1\+\1\=\2
对所有字符都转义,但是这种不建议使用。
而正则表达式必须要使用定界符包围起来,在JavaScript中定界符是“/”,而在PHP中,比较常见的是用“/”定界,也可以用“#”定界,而且外面还需要用引号包围起来。
如果正则表达式包含这些定界符,您就需要对这些字符进行转义。
PHP 正则表达式定界符
大多数语言的正则表达式都是由“/”作为定界符的,而在PHP中,还可以使用“#”定界,如果字符串中包含大量“/”字符,在使用“/”定界的时候,就需要对这些“/”转义,而使用“#”就不需要转义,更简洁。
<?php $subject='钱运来PHP博客的网址是 http://blog.snsgou.com/_blog/ ,你能把这个网址替换成正确的网址吗?'; // 上面的要求就是把 http://blog.snsgou.com/_blog 替换成 http://blog.snsgou.com/ // . : - 都是正则符号,所以需要转义,而 / 是定界符,如果字符串中包含 / 定界符,就需要转义 echo preg_replace('/http\:\/\/www\.qianyunlai\.com\/\_blog\//', 'http://blog.snsgou.com/', $subject); echo '<br />'; // 在 #作为定界符,/ 就不再是定界符的含义,就不需要转义了。 echo preg_replace('#http\://www\.qianyunlai\.com/\_blog/#', 'http://blog.snsgou.com/', $subject); // 上面两条输出结果都一样,【钱运来PHP博客的网址是 http://blog.snsgou.com/,你能把这个网址替换成正确的网址吗?】 ?>
通过上面的两条PHP 正则替换代码我们可以发现,如果正则语句中包含大量“/”,无论使用“/” 还是 “#”做定界符都是可以的,但是使用“#”能让代码看起来更简洁。但还是建议您保持使用“/”作为定界符,因为在JavaScript等语言中,只能使用“/”作为定界符,这样写起来可以形成习惯,贯通于其他语言中。
PHP 正则表达式修饰符
修饰符被放在PHP正则表达式定界符“/”之后,在正则表达式尾部引号之前。
i 忽略大小写,匹配不考虑大小写
m 多行独立匹配,如果字符串不包含[\n]等换行符就和普通正则一样。
s 设置正则符号 . 可以匹配换行符[\n],如果没有设置,正则符号.不能匹配换行符\n。
x 忽略没有转义的空格
e eval() 对匹配后的元素执行函数。
A 前置锚定,约束匹配仅从目标字符串开始搜索
D 锁定$作为结尾,如果没有D,如果字符串包含[\n]等换行符,$依旧依旧匹配换行符。如果设置了修饰符m,修饰符D 就会被忽略。
S 对非锚定的匹配进行分析
U 非贪婪,如果在正则字符量词后加“?”,就可以恢复贪婪
X 打开与perl 不兼容附件
u 强制字符串为UTF-8编码,一般在非UTF-8编码的文档中才需要这个。建议UTF-8环境中不要使用这个。
如果您熟悉JavaScript 的正则表达式,或许一定熟悉JavaScript 正则表达式的修饰符“g”,代表匹配所有符合条件的元素。而在PHP 正则替换中,是匹配所有符号条件的元素,所以不存在JavaScript 修饰符“g”。
PHP 正则中文和忽略大小写
PHP preg_replace() 是区分大小写的,同时只能匹配ASCII编码内的字符串,如果需要匹配不区分大小写和中文等字符需要添加相应的修饰符 i 或 u。
<?php $subject='钱运来PHP博客网址:http://www.QIanyunlai.com/'; // 大小写不同,输出【钱运来PHP博客网址:http://www.QIanyunlai.com/】 echo preg_replace('/QIAN/', 'qian', $subject); echo '<br />'; // 忽略大小写,执行替换输出【钱运来PHP博客网址:http://blog.snsgou.com/】 echo preg_replace('/QIAN/i', 'qian', $subject); echo '<br />'; // 强制 UTF-8中文,执行替换,输出【钱运来PHP博客:http://www.QIanyunlai.com/】 echo preg_replace('/网址/u', '', $subject); ?>
大小写和中文在PHP中都是敏感的,但是在JavaScript正则中,只对大小写敏感,忽略大小写也是通过修饰符 i 作用的,但是JavaScript 不需要告知是否是UTF-8中文等特殊字符,直接可以匹配中文。
PHP 正则换行符实例
PHP 正则表达式在遇到换行符时,会将换行符当做字符串中间一个普通字符。而通用符号.不能匹配\n,所以遇到带有换行符的字符串正则会有很多要点。
<?php $subject="snsgou.com\nIS\nLOVING\nYOU"; // 想要把上面$subject 替换成snsgou.com echo preg_replace('/^[A-Z].*[A-Z]$/', '', $subject), '<br />'; // 这个正则表达式是,匹配只包含\w的元素,$subject 是以q开头,符合[A-Z],而且结尾是m,也符合[A-Z]。.无法匹配\n // 输出【snsgou.com IS LOVEING YOU】 echo preg_replace('/^[A-Z].*[A-Z]$/s', '', $subject), '<br />'; // 这个用修饰符s,也就是 . 可以匹配 \n 了,所以整句匹配,输出空 // 输出【】 echo preg_replace('/^[A-Z].*[A-Z]$/m', '', $subject), '<br />'; // 这里使用了修饰符,将\n作为多行独立匹配。也就等价于: /* $preg_m = preg_replace('/^[A-Z].*[A-Z]$/m', '', $subject); $p = '/^[A-Z].*[A-Z]$/'; $a = preg_replace($p, '', 'snsgou.com'); $b = preg_replace($p, '', 'IS'); $c = preg_replace($p, '', 'LOVING'); $d = preg_replace($p, '', 'YOU'); $preg_m === $a . $b . $c . $d; */ // 输出【snsgou.com】 ?>
以后您在使用PHP 抓取某个网站内容,并用正则批量替换的时候,总无法避免忽略获取的内容包含换行符,所以在使用正则替换的时候一定要注意。
PHP 正则匹配执行函数
PHP 正则替换可以使用一个修饰符e,代表 eval() 来执行匹配后的内容某个函数。
<?php $subject='钱运来PHP博客网址:http://www.qianYUNlai.com/'; // 将上面网址转为小写 echo preg_replace('/(http\:[\/\w\.\-]+\/)/e', 'strtolower("$1")', $subject); // 使用修饰符e之后,就可以对匹配的网址执行PHP 函数 strtolower() 了 // 输出 【钱运来PHP博客网址:http://blog.snsgou.com/】 ?>
根据上面代码,尽管匹配后的函数 strtolower() 在引号内,但是依旧会被eval()执行。
正则替换匹配变量向后引用
如果您熟悉JavaScript,一定对$1 $2 $3 …… 等向后引用比较熟悉,而在 PHP 中这些也可以被当作向后引用参数。而在PHP中,还可以使用 \1 \\1 来表示向后引用。
向后引用的概念就是匹配一个大片段,这个正则表达式内部又被用括号切割成若干小匹配元素,那么每个匹配元素就被按照小括号序列用向后引用代替。
<?php $subject='钱运来PHP博客网址:http://blog.snsgou.com/,你yun-lai了吗?'; echo preg_replace('/.+(http\:[\w\-\/\.]+\/)[^\w\-\!]+([\w\-\!]+).+/', '$1', $subject); echo preg_replace('/.+(http\:[\w\-\/\.]+\/)[^\w\-\!]+([\w\-\!]+).+/', '\1', $subject); echo preg_replace('/.+(http\:[\w\-\/\.]+\/)[^\w\-\!]+([\w\-\!]+).+/', '\\1', $subject); // 通常用这个 echo '<br />'; // 上面三个都是输出 【http://blog.snsgou.com/】 echo preg_replace('/^(.+)网址:(http\:[\w\-\/\.]+\/)[^\w\-\!]+([\w\-\!]+).+$/', '栏目:$1<br>网址:$2<br>商标:$3', $subject); /* 栏目:钱运来PHP博客 网址:http://blog.snsgou.com/ 商标:yun-lai */ echo '<br />'; // 括号中括号,外面括号先计数 echo preg_replace('/^((.+)网址:(http\:[\w\-\/\.]+\/)[^\w\-\!]+([\w\-\!]+).+)$/', '原文:$1<br>栏目:$2<br>网址:$3<br>商标:$4', $subject); /* 原文:钱运来PHP博客网址:http://blog.snsgou.com/,你yun-lai了吗? 栏目:钱运来PHP博客 网址:http://blog.snsgou.com/ 商标:yun-lai */ ?>
Das obige ist der detaillierte Inhalt vonSo implementieren Sie regelmäßige Ersatzinhalte in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!