PHP正則

定界符

/$%^@
示例
/正則表達式/
$正則表達式$

簡單匹配

$pattern = '/a/';

$string = 'abcdabdc';

if(preg_match($pattern, $string, $matches)){
   echo '匹配到了,結果爲:';
   var_dump($matches);
}else{
   echo '沒有匹配到';
}

//如果值匹配一次,可以啓用第四個參數,詳情請參考:https://blog.csdn.net/liuxl57805678/article/details/103311638

 

1、通用原子:

  • \d : 數字。  \D : 除了數字。
  • \w : 數字,字母,下劃線。\W : 除了數字,字母,下劃線。
  • \s  : 空白符 。 \S : 除了空白符  。

 2、元字符:

  • . :除了換行以外的所有字符
  • * : 匹配前面的內容出現 0 次及以上。
  • ? : 匹配前面的內容出現 0 次或 1 次
  • + : 出現一次或多次。
  • ^ : 必須以它開頭。
  • $ : 必須以它結尾。
  • {n} : 恰巧出現 n 次。
  • {n,} : 大於等於 n 次。
  • {n,m} : 大於等於 n, 小於等於 m.
  • [] : 是一個集合,匹配中括號中的任意一個字符,如:[abc]即爲匹配a或b或者c。
  • () : 後項引用 或者是當做一個整體。
  • [^]: 取反。
  • | : 或者
  • [-] : 代表一個範圍,如[0-9],匹配即爲 0123456789

 3、模式修正符

i :(PCRE_CASELESS)
  如果設定此修正符,模式中的字符將同時匹配大小寫字母。
m:(PCRE_MULTILINE)
  默認情況下,PCRE 將目標字符串作爲單一的一“行”字符所組成的(甚至其中包含有換行符也是如此)。“行起始”元字符(^)僅僅匹配字符串的起始,“行結束”元字符()僅僅匹配字符串的結束,或者最後一個字符是換行符時其前面(除非設定了D修正符)。這和Perl是一樣的。  當設定了此修正符,“行起始”和“行結束”除了匹配整個字符串開頭和結束外,還分別匹配其中的換行符的之後和之前。這和Perl的/m修正符是等效的。如果目標字符串中沒有“\n”字符或者模式中沒有或)僅僅匹配字符串的結束,或者最後一個字符是換行符時其前面(除非設定了D修正符)。這和Perl是一樣的。  當設定了此修正符,“行起始”和“行結束”除了匹配整個字符串開頭和結束外,還分別匹配其中的換行符的之後和之前。這和Perl的/m修正符是等效的。如果目標字符串中沒有“\n”字符或者模式中沒有或,則設定此修正符沒有任何效果。
s:(PCRE_DOTALL)
  如果設定了此修正符,模式中的圓點元字符(.)匹配所有的字符,包括換行符(一般情況下‘.’是不能匹配‘\n’的)。沒有此設定的話,則不包括換行符。這和 Perl 的 /s 修正符是等效的。排除字符類例如 [^a] 總是匹配換行符的,無論是否設定了此修正符。
x:(PCRE_EXTENDED)
  如果設定了此修正符,模式中的空白字符除了被轉義的或在字符類中 的以外完全被忽略,在未轉義的字符類之外的 # 以及下一個換行符之間的所有字符,包括兩頭,也都被忽略。這和 Perl 的 /x 修正符是等效的,使得可以在複雜的模式中加入註釋。然而注意,這僅適用於數據字符。空白字符可能永遠不會出現於模式中的特殊字符序列,例如引入條件子模式 的序列 (?( 中間。
e:
  如果設定了此修正符,preg_replace() 在替換字符串中對逆向引用作正常的替換,將其作爲 PHP 代碼求值,並用其結果來替換所搜索的字符串。
  只有 preg_replace() 使用此修正符,其它 PCRE 函數將忽略之。
  注: 本修正符在 PHP3 中不可用。
A:(PCRE_ANCHORED)
  如果設定了此修正符,模式被強制爲“anchored”,即強制僅從目標字符串的開頭開始匹配。此效果也可以通過適當的模式本身來實現(在 Perl 中實現的唯一方法)。
D:(PCRE_DOLLAR_ENDONLY)
  如果設定了此修正符,模式中的美元元字符僅匹配目標字符串的結尾。沒有此選項時,如果  最後一個字符是換行符的話,美元符號也會匹配此字符之前(但不會匹配任何其它換行符之前)。如果設定了 m 修正符則忽略此選項。Perl 中沒有與其等價的修正符。
S:
  當一個模式將被使用若干次時,爲加速匹配起見值得先對其進行分析。如果設定了此修正符則會進行額外的分析。目前,分析一個模式僅對沒有單一固定起始字符的 non-anchored 模式有用。
U:(PCRE_UNGREEDY)
  本修正符反轉了匹配數量的值使其不是默認的重複,而變成在後面跟上“?”才變得重複。這和 Perl 不兼容。也可以通過在模式之中設定 (?U) 修正符或者在數量符之後跟一個問號(如 .*?)來啓用此選項。
X:(PCRE_EXTRA)
  此修正符啓用了一個 PCRE 中與 Perl 不兼容的額外功能。模式中的任何反斜線後面跟上一個沒有特殊意義的字母導致一個錯誤,從而保留此組合以備將來擴充。默認情況下,和 Perl 一樣,一個反斜線後面跟一個沒有特殊意義的字母被當成該字母本身。當前沒有其它特性受此修正符控制。
u:(PCRE_UTF8)
  此修正符啓用了一個 PCRE 中與 Perl 不兼容的額外功能。模式字符串被當成 UTF-8。本修正符在 Unix 下自 PHP 4.1.0 起可用,在 win32 下自 PHP 4.2.3 起可用。自 PHP 4.3.5 起開始檢查模式的 UTF-8 合法性。

 

元字符

* 匹配前面的一個原子,匹配0次或者任意多次
+ 匹配一次或多次
? 前面的字符可有可無(可選)
. 匹配除了\n以外的所有字符
^ 必須要以抑揚符之後的字符串開始
$ 必須要以$之前的字符結尾
\b 詞邊界
\B 非邊界
{m} 有且只能出現m次
{n,m} 可以出現n到m次
{m,} 至少m次,最大次數不限制
() 改變優先級或者將某個字符串視爲一個整體,匹配到的數據取出來也可以使用它

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章