欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

如何在c++11中使用regex正則表達(dá)式-創(chuàng)新互聯(lián)

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)如何在c++11中使用regex正則表達(dá)式,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

成都創(chuàng)新互聯(lián)是一家專業(yè)提供陸良企業(yè)網(wǎng)站建設(shè),專注與成都做網(wǎng)站、成都網(wǎng)站建設(shè)、H5響應(yīng)式網(wǎng)站、小程序制作等業(yè)務(wù)。10年已為陸良眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。

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

  • 以std::string為代表的處理字符串的類型(我們知道還有存儲wchar_t的wstring類、原生c式字符串const char*等等,為了簡化處理僅介紹std::string類型相關(guān)的操作,當(dāng)你把握住了regex的主脈絡(luò)之后,想使用其他的版本只要類比就可以)

  • std::regex類,該類型需要一個代表正則表達(dá)式的字符串和一個文法選項作為輸入,當(dāng)文法選項不提供時默認(rèn)為ECMAScript。

  • std::match_results類,該類用來記錄匹配的結(jié)果,這是一個模板類,該類的模板參數(shù)是一個迭代器類型,對于std::string來說我們定義了smatch作為match_results<string::const_iterator>作為別名。

  • std::sub_match類,該類其實封裝了兩個迭代器,第一個代表開始部分,第二個代表結(jié)束部分,就像你用兩個下表索引去表達(dá)一個字符串的某一個子串一樣。這個類就是通過這樣的方式提供原字符串的某一個子串作為結(jié)果。實際上match_results中就封裝了一些std::sub_match類型的對象。(為什么是一些而不是一個,因為一次匹配可能會產(chǎn)生多個結(jié)果返回,regex認(rèn)為每個括號對構(gòu)成一個子匹配項,regex匹配的結(jié)果可以顯式每個子匹配項匹配到的內(nèi)容。)

  • 現(xiàn)在我們有了表達(dá)字符串的類,表達(dá)正則匹配的類,表達(dá)匹配結(jié)果的類,接下來regex提供三個匹配函數(shù):

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

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

看幾個例子:

#include <iostream>
#include <string>
#include <regex>

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;
}

匹配失敗,什么都不會輸出。

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

#include <iostream>
#include <string>
#include <regex>

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;
}

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

#include <iostream>
#include <string>
#include <regex>

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 <iostream>
#include <string>
#include <regex>

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。

上述就是小編為大家分享的如何在c++11中使用regex正則表達(dá)式了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.chinadenli.net,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)站名稱:如何在c++11中使用regex正則表達(dá)式-創(chuàng)新互聯(lián)
本文URL:http://www.chinadenli.net/article28/ccepcp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站App開發(fā)定制網(wǎng)站域名注冊App設(shè)計定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)