您好,登錄后才能下訂單哦!
如何理解php的正則表達式,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
\d : 數(shù)字。 \D : 除了數(shù)字。
\w : 數(shù)字,字母,下劃線。\W : 除了數(shù)字,字母,下劃線。
\s : 空白符 。 \S : 除了空白符 。
. :除了換行以外的所有字符
* : 匹配前面的內(nèi)容出現(xiàn) 0 次及以上。
? :匹配前面的內(nèi)容出現(xiàn) 0 次或 1 次。
+ : 出現(xiàn)一次或多次。
^ : 必須以它開頭。
$ : 必須以它結尾。
{n} : 恰巧出現(xiàn) n 次。
{n,} : 大于等于 n 次。
{n,m} : 大于等于 n, 小于等于 m.
[] : 是一個集合,匹配中括號中的任意一個字符,如:[abc]即為匹配a或b或者c。
() : 后項引用或者是當做一個整體。
[^]:取反。
| : 或者
[-] : 代表一個范圍,如[0-9],匹配即為 0123456789
i:不區(qū)分大小寫。
m:將字符串通過分隔符進行分割,將字符串中的每一行分別進行匹配。
e: 將匹配出來的內(nèi)容做一些php語法上的處理。
s: 修正 "." 的換行。
U: 取消貪婪模式。
x: 忽略模式中的空白符。
A: 必須以這個模式開頭。
D: 修正 "$" 對 "\n" 的忽略。
u: 做 utf-8 中文匹配的時候使用。
g:該表達式可以進行全局匹配。
現(xiàn)在需要正則驗證一個input框,我想輸入的是非整數(shù)就自動變成空值。
正則如下;
#不加入/g,則只返回第一個匹配,無論執(zhí)行多少次均是如此,如果加入g,則第一次執(zhí)行也返回第一個匹配,再執(zhí)行返回第二個匹配,依次類推。#/[^0-9]/g,這個正則表達式的意思是全局匹配非數(shù)字類型和非-的字符。/[^0-9|-]/g
匹配到該正則后,就將input的值置空即可。
如果想只去除掉b標簽,只保留里面的字符串,這里就需要用到后項引用。怎么樣后項引用呢,就是將.* 括起來,然后在匹配的時候,寫上\1,\1 代表第一個括號里面匹配到的內(nèi)容,當然為了防止 \ 將 1 轉義掉,所以我們使用\\1 .
我們這是想匹配到每一個 b 標簽,即<b>abc</b>和<b>bcd</b>,
//如果使用下面的正則來匹配的話,會匹配出<b>abc</b><b>bcd</b>.$pattern='/<b>.*<\/b>/';
所以此處我們要使用.*?來取消貪婪,?代表匹配前面的內(nèi)容 0 次或者 1次。
//正則表達式改為$pattern='/<b>.*?</b>/';//當然取消貪婪還有一種寫法:就是在后面加上一個U,即:$pattern='/<b>.*</b>/U';
但是切記不能 .*? 和 U 一起用。
$str = '中文';
a、使用utf-8匹配中文:
$pattern='/[\x{4e00}-\x{9fa5}]+/u';
b、使用GB2312匹配中文:
$pattern='/['.chr(0xb0).'-'.chr(0xf7).']['.chr(0xa1).'-'.chr(0xfe).']/';preg_match($pattern,$str,$match);
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業(yè)資訊頻道,感謝您對億速云的支持。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。