C++ Primer 5th笔记(chap 17 标准库特殊设施)子表达式subexpression
生活随笔
收集整理的這篇文章主要介紹了
C++ Primer 5th笔记(chap 17 标准库特殊设施)子表达式subexpression
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
1. 正則表達(dá)式的模式通常包含一個或多個子表達(dá)式
通常用括號表示子表達(dá)式
eg. r 有兩個子表達(dá)式: 第一個是點之前表示文件名的部分, 第二個表示文件擴展名
regex r ("([[:alnum:] ]+)\\ ? (cpp丨cxx丨cc ) $", regex::icase);1.1 匹配對象除了提供匹配整體的相關(guān)信息外 ,還提供訪問模式中每個子表達(dá)式的能力
子匹配是按位置來訪問的。 第一個子匹配位置為 0. 表示整個模式對應(yīng)的匹配, 隨后是每
個子表達(dá)式對應(yīng)的匹配。
eg.
//模式中第一個子表達(dá)式, 即表示文件名的子表達(dá)式,其位置為1 //文件擴展名對應(yīng)的子表達(dá)式位置為2//如 果 文 件 名 為 foo.cpp , 則 results.str 將 保 存 foo.cpp ; //results.str(1)將保存foo: //results.str(2)將保存cpp if (regex_search(filename, results, r))cout << results.str(1) << endl; // .str(1)獲取第一個子表達(dá)式匹配結(jié)果1.2 子表達(dá)式用于數(shù)據(jù)驗證
子表達(dá)式的一個常見用途是驗證必須匹配特定格式的數(shù)據(jù)。
step1. 將用一個正則表達(dá)式找到可能是電話號碼的序列
step2. 調(diào)用一個函數(shù)來完成數(shù)據(jù)驗證
1.3 子匹配操作
| 操作 | 描述 |
| matched | 一個public bool數(shù)據(jù)成員,指出了此ssub_match是否匹配了public數(shù)據(jù)成員, |
| first | 指向匹配序列首元素和尾后元素位置的迭代器,若未匹配 |
| second | 則first和second是相等的 |
| length() | 匹配的大小。若matched為false,則返回0 |
| str() | 返回一個包含輸入中匹配部分的string。若matched為false,則返回空string |
| s = ssub | 將ssub_match對象ssub轉(zhuǎn)化為string對象s |
總結(jié)
以上是生活随笔為你收集整理的C++ Primer 5th笔记(chap 17 标准库特殊设施)子表达式subexpression的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C++ Primer 5th笔记(cha
- 下一篇: C++ Primer 5th笔记(cha