C++的正则封装的不丰富.只有最基础的三个主要的函数(也可能是我孤陋寡闻).要有更为丰富的功能需要自己进一步组合.
我目前只需要循环查找这个功能,并且我也不知道c++的正则支持正则的哪些功能;
代码如下,后面要用到其他的诸如替换之类的功能在来补充
#include#include #include #include using namespace std;int main(void){ string s = "The operation to complete"; regex r("\\b\\w+?\\b"); //字符串构造有点不一样. smatch m; //是个容器. while (regex_search(s, m, r)) { cout << m.str() << endl; s = m.suffix().str(); //关键,实现循环查找的重要步骤. } system("pause"); return 0;}
输出:
封装一下简单实现类似Python中的findall的功能:
//Regular是正则表达式//text是被匹配的文本//函数功能是返回文本中所有被匹配的值//此函数依赖vector库,regex库,string库vectorfindall(string Regular, string &text){ vector ret; ret.clear(); regex r(Regular); smatch m; //是个容器. string str=text; while (regex_search(str, m, r)) { ret.push_back(m.str()); str = m.suffix().str(); //关键,实现循环查找的重要步骤. //不加以判断的话可能会无限循环 //比如text的内容是"a".判别式是"\\b.*?\\b",这样就会无限循环,这是属于判别式的锅,因为*代表0-无穷个可能,然后又加了?代表0个或者1个. if (str == text) { return ret; } } return ret;}