C語言中的正則表達式使用_第1頁
C語言中的正則表達式使用_第2頁
C語言中的正則表達式使用_第3頁
C語言中的正則表達式使用_第4頁
C語言中的正則表達式使用_第5頁
已閱讀5頁,還剩1頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領

文檔簡介

C語言中的正則表達式使用

語中的正則表達式使正則表達式,稱正規(guī)表法、常規(guī)表法英,語在:代碼中常簡寫、為或,計算機科學的個概念。

正則表達式是使單個字符串來描述、匹配系列符合某個句法規(guī)章的--字來符串百。

度百科在語中,、、和處理正則表達式。

處理正則表達式分三步:,;,;,。

四個函數(shù)的具體解釋:*,*;函數(shù)說明:將正則表達式字符編串譯成的形式,后續(xù)以此進搜尋。

參數(shù)說明::個結(jié)構(gòu)體指針。

:正則表達式字符串。

:是下邊四個值或者是|運他算們。

的或_:使擴展正則表達式語法解釋的正則表達式。

假如正沒則有表設達置式,語基法本。

_:忽視字母的寫。

_:不存儲匹配的結(jié)果。

_:對換符“特進殊照”,顧后邊具體說明。

返回值:0:表勝利編譯;0:表編譯失敗,查看失敗信息_*,*,_,;[],函數(shù)說明:來匹配正則本。

參數(shù)說明::編譯好的結(jié)構(gòu)體指針,:要進正則匹配的字符串。

:結(jié)構(gòu)體數(shù)組的:結(jié)構(gòu)體數(shù)組。

來保存匹配結(jié)果的串位置。

結(jié)構(gòu)體定義如下{__;__;}_;_,它的值假如-1,不表為匹配的最串在字符串中的_起,始表偏移匹量配,的最字串在字符串的結(jié)束偏移量。

:_和為兩個值之或|運者算的,或稍后會介紹。

返回值:0:表勝利編譯;0:表編譯失敗,查看失敗信息_*;函數(shù)說明:釋放編譯好的內(nèi)置變量。

參數(shù)說明::編譯好的結(jié)構(gòu)體指針。

_,_*,*,__;函數(shù)說明:,出錯時,會返回并且為0此時就可,以得到錯誤信息。

參數(shù)說明::,出錯時的返回值:過編譯的結(jié)構(gòu)體指針。

:錯誤信息放置的位置。

_:錯誤信息的。

好現(xiàn)在開頭寫個簡潔的正則匹配程序。

代碼如下:1#2#3#4#567{8[256];9;10;11_;1213=_|_|_;1415*_=;16*_.;*=1718=,_,;1920{21,256;,,22,%\,;23;24}2526=,0,0;_,2728{29,256;,,30,%\,;31;32}3334,256,;,35,:\%\,;3637:38;39400;41}編譯,輸出結(jié)果:[**@]#.:匹配勝利。

假如我想保留匹配的結(jié)果怎么操作那就結(jié)得構(gòu)體到了。

重新改寫上邊代碼,這時就不選能項了,代碼如下:1#_2#3#4#5#6#789{1011;12[256];13;14;15_;165];_[17*_=;1819=_|_;2023*_=;22*_.=*;2324=,_,;2526{27,256;,,28,%\,;29;30}3132=,5,,0;_,3334{35,256;,,36,%\,;37;38}3940,256,;,41,:\%\\,;4243=0;5;++44{45[]._1-46{47_=_+[]._,[]._-[]._;48%\,,;49_;50_=;51}52}5354:55;56570;58}編譯,輸出結(jié)果:[**@]#.:咦我明明只要個匹配結(jié)果,為什么會打印兩個出來呢原來數(shù)組的第個元素是有特別意義的:它是來保存整個正則表達式能匹所配以的我最們在設串置的起數(shù)始組和個結(jié)數(shù)束的偏時移候量。

定要記住,它的個數(shù)是最保留結(jié)果+1數(shù)。

好了,基本的正則運到此為了,現(xiàn)在要開、始講_講和_。

許多對這三個參數(shù)有所迷惑。

我也是,昨天有問問題,就把錯誤的理解告知了別,然后被神頓鄙視。

我^直和$認這為兩如個果匹想配模式定要_到這個參數(shù),其實不然。

先看下對_的說明:_--’.-[^...].--^-,,,_.$,不好,翻譯之。

。

運如算.不符匹配換\;2.匹配列[^表...]不包含個換符不匹配個換符;^算遇符到空字符串即換,不論在時執(zhí),是否設置了_;$算遇符到空字符串即換,不論在時執(zhí),是否設置了_;不明說的是什么,程序測之。

。

第個問題,代碼如下:1#_2#3#4#5#6#789{1011;12[256];13;14;1516_;1718=_|_|_;1920*_=\;212*_=;.23=,_,;2425{26,256;,,27,1.%\,;28;29}3031=,0,,0;_,32,256,;,33,2.%\,;3435|=_;3637=,_,;3839{40,256;,,41,3.%\,;42;43}4445=,0,,0;_,46,256,;,47,4.%\,;4849:50;51520;53}編譯,運結(jié)果如下:[**@]#.:沒有_加的匹配勝利,加的匹配不勝利。

就_是說不,加任意匹配.字包符含\,加則不\包。

含第個問題,代碼如下:1#_2#3#4#5#6#789{1011;12[256];13;14;1516_;1718=_|_|_;1920*_\=;21*_[^=;]2223=,_,;2425{26,256;,,27,1.%\,;28;29}3031=,0,,0;_,32,256,;,33,2.%\,;3435|=_;3637=,_,;3839{40,256;,,41,3.%\,;42;43}4445=,0,,0;_,46,256,;,47,4.%\,;4849:50;51520;53}編譯,運結(jié)果如下:[**@]#.:不加,在個不\包的含列表\中是,不被認作空符\,是加被認則作空符。

第三個問題,代碼如下:1#_2#3#4#5#6#789{1011;12[256];13;14;1516_;1718=_|_|_;1920*_\=;21*_^=;2223=,_,;2425{26,256;,,27,1.%\,;28;29}3031=,0,,0;_,323,,2.%\,;256,;,3435|=_;3637=,_,;3839{40,256;,,41,3.%\,;42;43}4445=,0,,0;_,46,256,;,47,4.%\,;4849:50;51520;53}編譯,運結(jié)果如下:[**@]#.:不加,^是不忽\略的,加_,^是忽\略的。

也就是說:不加,以\開頭的字符串是^不匹能配,加_,以\開頭的字符串是^可匹以配。

第四個問題,代碼如下:1#_2#3#4#5#6#789{1011;12[256];13;14;1516_;1718=_|_|_;1920*_=\;21*_;=$2223=,_,;2425{26,256;,,27,1.%\,;28;29}3031=,0,,0;_,32,256,;,33,2.%\,;3435|=_;3637=,_,;3839{40,256;,,41,3.%\,;42;43}4445=,0,,0;_,46,256,;,47,4.%\,;4849:50;51520;53}編譯,運結(jié)果如下:[**@]#.:不加,$是不忽\略的,加_,$是忽\略的。

也就是說:不加,以\結(jié)尾的字符串是$不匹能配,加_,以\開頭的字符串是$可匹以配。

好,_選項測試到此結(jié)束。

總結(jié)下:對于_選項1,使.任意匹.配時符,任意匹配符不\會;個不\含的有列表,\會認把作空3符對.。

于\以開頭或結(jié)尾的字符串\,。

會使^忽和略可以使$。

現(xiàn)在開頭說下_和_,先看下對這兩選項的說明:____繼續(xù)。

_匹配開頭^操會作經(jīng)符常匹配但失是敗要考慮_,這個標志被在當個字符串的不同位時置,被這傳個位到置不應當被解釋為該整個字符串的開頭位置。

_匹配結(jié)束操會作經(jīng)符常失$但敗是要考慮_。

這個標志被在當個字符串的不同位置時被,傳即使到滿匹配結(jié)束作符,也不應當串被為解結(jié)釋束為的以某。

字符好吧,連續(xù)測試,第個問題代碼如下:1#_2#3#4#5#6#789{1011;12[256];13;14;1516_;1718=_|_|_;1920*_=\;21*^;=2223=,_,;2425{26,256;,,27,1.%\,;28;29}3031=,1,0,,0;+32,256

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論