正則表達(dá)式
正則表達(dá)式,又稱規(guī)則表達(dá)式。(英語(yǔ):Regular Expression,在代碼中常簡(jiǎn)寫為regex、regexp或RE),計(jì)算機(jī)科學(xué)的一個(gè)概念。正則表達(dá)式通常被用來(lái)檢索、替換那些符合某個(gè)模式(規(guī)則)的文本。
許多程序設(shè)計(jì)語(yǔ)言都支持利用正則表達(dá)式進(jìn)行字符串操作。例如,在Perl中就內(nèi)建了一個(gè)功能強(qiáng)大的正則表達(dá)式引擎。正則表達(dá)式這個(gè)概念最初是由Unix中的工具軟件(例如sed和grep)普及開(kāi)的。正則表達(dá)式通??s寫成“regex”,單數(shù)有regexp、regex,復(fù)數(shù)有regexps、regexes、regexen。
下面給大家介紹正則表達(dá)式的使用規(guī)則,具體內(nèi)容如下所示:
d | 匹配0-9中的任意一個(gè)數(shù)字,等效于[0-9]
D | 匹配非數(shù)字字符,等效于[^0-9]
w | 匹配任意一個(gè)字母、數(shù)字或下劃線,等效于[^A-Za-z0-9_]
W | 與任何非字母、數(shù)字或下劃線字符匹配,等效于[^A-Za-z0-9_]
s | 匹配任何空白字符,包括空格、制表符、換頁(yè)符,等效于 ?[fnrtv]
S | 匹配任何非空白字符,等效于[^fnrtv]
n | 匹配換行符
r | 匹配一個(gè)回車符
t | 匹配制表符
v | 匹配垂直制表符
f | 匹配換頁(yè)符
這些字符在正則表達(dá)式中表示特殊的含義,比如:*,+,?,,
| 轉(zhuǎn)義字符,將下一個(gè)字符標(biāo)記為一個(gè)特殊字符
^ | 匹配字符串開(kāi)始的位置
$ | 匹配字符串結(jié)尾的位置
* | 零次或多次匹配前面的字符或子表達(dá)式
+ | 一次或多次匹配前面的字符或子表達(dá)式
? | 零次或一次匹配前面的字符或子表達(dá)式
. | “點(diǎn)” 匹配除“rn”之外的任何單個(gè)字符
| | 或
[ ] | 字符集合
( ) | 分組,要匹配圓括號(hào)字符,請(qǐng)使用 “(” ?或 “)”
限定字符又叫量詞,是用于表示匹配的字符數(shù)量的。
* | 零次或多次匹配前面的字符或子表達(dá)式
+ | 一次或多次匹配前面的字符或子表達(dá)式
? | 零次或一次匹配前面的字符或子表達(dá)式
{n} | n是一個(gè)非負(fù)整數(shù),匹配確定的n次
{n,} | n是非負(fù)整數(shù),至少匹配n次
{n,m} | n和m是非負(fù)整數(shù),其中n<=m;匹配至少n次,至多m次
定位字符也叫字符邊界,標(biāo)記匹配的不是字符而是符合某種條件的位置,所以定位字符是“零寬的”。
^ | 匹配字符串開(kāi)始的位置,表示開(kāi)始
$ | 匹配字符串結(jié)尾的位置,表示結(jié)尾
b | 匹配一個(gè)單詞邊界
總結(jié)
以上所述是小編給大家介紹的正則表達(dá)式的使用規(guī)則,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!