真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

c++11中如何使用regex正則表達(dá)式

c++11中如何使用regex正則表達(dá)式,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

創(chuàng)新互聯(lián)是網(wǎng)站建設(shè)專家,致力于互聯(lián)網(wǎng)品牌建設(shè)與網(wǎng)絡(luò)營(yíng)銷,專業(yè)領(lǐng)域包括成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、成都外貿(mào)網(wǎng)站建設(shè)、電商網(wǎng)站制作開發(fā)、微信小程序定制開發(fā)、微信營(yíng)銷、系統(tǒng)平臺(tái)開發(fā),與其他網(wǎng)站設(shè)計(jì)及系統(tǒng)開發(fā)公司不同,我們的整合解決方案結(jié)合了恒基網(wǎng)絡(luò)品牌建設(shè)經(jīng)驗(yàn)和互聯(lián)網(wǎng)整合營(yíng)銷的理念,并將策略和執(zhí)行緊密結(jié)合,且不斷評(píng)估并優(yōu)化我們的方案,為客戶提供全方位的互聯(lián)網(wǎng)品牌整合方案!

regex庫中涉及到的主要類型有:

以std::string為代表的處理字符串的類型(我們知道還有存儲(chǔ)wchar_t的wstring類、原生c式字符串const char*等等,為了簡(jiǎn)化處理僅介紹std::string類型相關(guān)的操作,當(dāng)你把握住了regex的主脈絡(luò)之后,想使用其他的版本只要類比就可以)  std::regex類,該類型需要一個(gè)代表正則表達(dá)式的字符串和一個(gè)文法選項(xiàng)作為輸入,當(dāng)文法選項(xiàng)不提供時(shí)默認(rèn)為ECMAScript。  std::match_results類,該類用來記錄匹配的結(jié)果,這是一個(gè)模板類,該類的模板參數(shù)是一個(gè)迭代器類型,對(duì)于std::string來說我們定義了smatch作為match_results作為別名。  std::sub_match類,該類其實(shí)封裝了兩個(gè)迭代器,第一個(gè)代表開始部分,第二個(gè)代表結(jié)束部分,就像你用兩個(gè)下表索引去表達(dá)一個(gè)字符串的某一個(gè)子串一樣。這個(gè)類就是通過這樣的方式提供原字符串的某一個(gè)子串作為結(jié)果。實(shí)際上match_results中就封裝了一些std::sub_match類型的對(duì)象。(為什么是一些而不是一個(gè),因?yàn)橐淮纹ヅ淇赡軙?huì)產(chǎn)生多個(gè)結(jié)果返回,regex認(rèn)為每個(gè)括號(hào)對(duì)構(gòu)成一個(gè)子匹配項(xiàng),regex匹配的結(jié)果可以顯式每個(gè)子匹配項(xiàng)匹配到的內(nèi)容。)  現(xiàn)在我們有了表達(dá)字符串的類,表達(dá)正則匹配的類,表達(dá)匹配結(jié)果的類,接下來regex提供三個(gè)匹配函數(shù):

bool std::regex_match(...)bool std::regex_search(...)string std::regex_replace(...)//實(shí)際上返回類型是根據(jù)你輸入的數(shù)據(jù)類型對(duì)應(yīng)的basic_string類。

首先說明三個(gè)函數(shù)功能上的不同,std::regex_match是全文匹配,即它希望你輸入的字符串要和正則表達(dá)式全部匹配,才認(rèn)為匹配成功,否則匹配失敗,而std::regex_search是在你輸入的字符串中不斷搜索符合正則表達(dá)式描述的子字符串,然后將第一個(gè)匹配到的子字符串返回。std::regex_replace是在std::regex_search的基礎(chǔ)上更進(jìn)一步,可以將匹配的子字符串替換為你提供的字符串。

看幾個(gè)例子:

#include #include #include int main() { std::regex pattern("\\d{4}"); std::string content("hello_2018"); std::smatch result; if (std::regex_match(content, result, pattern)) { std::cout << result[0]; } system("pause"); return 0;}

匹配失敗,什么都不會(huì)輸出。

這里說明一下為什么輸出的是result[0],其實(shí)result[0]返回的就是一個(gè)sub_match類型的對(duì)象。regex中認(rèn)為正則表達(dá)式的每個(gè)括號(hào)對(duì)構(gòu)成一個(gè)子匹配項(xiàng),并認(rèn)為整個(gè)字符串作為0號(hào)子匹配項(xiàng),然后根據(jù)左括號(hào)出現(xiàn)的位置,從1號(hào)開始編號(hào),因此返回的result[0]就是匹配整個(gè)正則表達(dá)式的字符串。

#include #include #include int main() { std::regex pattern("\\d{4}"); std::string content("hello_2018 by_2017"); std::smatch result; if (std::regex_search(content, result, pattern)) { std::cout << result[0]; } system("pause"); return 0;}

搜索到第一個(gè)符合正則表達(dá)式的子串,輸出 2018。

#include #include #include int main() { std::regex pattern("\\d{4}"); std::string content("hello_2018 by_2017"); std::smatch result; auto begin = content.cbegin(); auto end = content.cend(); while (std::regex_search(begin, end, result, pattern)) { std::cout << result[0] << " "; begin = result[0].second; } system("pause"); return 0;}

用上述方式可以輸出字符串中所有符合正則表達(dá)式匹配要求的字符串,輸出 2018 2017。

#include #include #include int main() { std::regex pattern("\\d{4}"); std::string content("hello_2018 by_2017"); std::string result = std::regex_replace(content, pattern, "everyone"); std::cout << result; system("pause"); return 0;}

輸出 hello_everyone by_everyone。

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。


網(wǎng)頁標(biāo)題:c++11中如何使用regex正則表達(dá)式
URL分享:http://weahome.cn/article/jeesip.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部