码迷,mamicode.com
首页 > 其他好文 > 详细

使用Boost Regex 的regex_search进行遍历搜索

时间:2015-04-03 19:02:51      阅读:202      评论:0      收藏:0      [点我收藏+]

标签:

在regex_search函数中,会将找到的第一个匹配结果保存到一个smatch类中。

然而如果搜索字符串中有多个匹配结果,则需要自己实现了。

在smatch中,有两个成员,官方文档如下:

iterator first:

An iterator denoting the position of the start of the match.

iterator second

An iterator denoting the position of the end of the match.

所以,使用如下方法,可以得到遍历搜索:

 

[cpp] view plaincopy技术分享技术分享
 
  1. #include <string>  
  2. #include <iostream>  
  3. #include <boost\regex.hpp>  
  4. int main()  
  5. {  
  6.     std::string str = "192.168.1.1";  
  7.   
  8.     boost::regex expression("\\d+");  
  9.     boost::smatch what;  
  10.   
  11.     std::string::const_iterator start = str.begin();  
  12.     std::string::const_iterator end = str.end();  
  13.     while ( boost::regex_search(start, end, what, expression) )  
  14.     {  
  15.         std::cout << what[0] << std::endl;  
  16.         start = what[0].second;  
  17.     }  
  18.     return 0;  
  19. }  

结果如下:

 

 

[plain] view plaincopy技术分享技术分享
 
  1. 192  
  2. 168  
  3. 1  
  4. 1  

在boost中,还提供了一种迭代器的方法,名称为:sregex_iterator,默认构造器会生成一个结束迭代器。用法如下:

 

[cpp] view plaincopy技术分享技术分享
 
  1. #include <string>  
  2. #include <iostream>  
  3. #include <boost\regex.hpp>  
  4. int main()  
  5. {  
  6.     std::string str = "192.168.1.1";  
  7.   
  8.     boost::regex expression("\\d+");  
  9.     boost::sregex_iterator it(str.begin(), str.end(), expression);  
  10.     boost::sregex_iterator end;  
  11.     for (; it != end; ++it)  
  12.         std::cout << *it << std::endl;  
  13.   
  14.     return 0;  
  15. }  

效果与上一例相同。
 
如果不需要遍历,只需要匹配,那更简单:
    boost::regex reg( szReg );
    bool r=boost::regex_match( szStr , reg);
或是需要放入一个cmatch 中:
{
    boost::cmatch mat;
    boost::regex reg( "\\d+" );    //查找字符串里的数字
    if(boost::regex_search(szStr, mat, reg))
    {
        cout << "searched:" << mat[0] << endl;
    }
}

使用Boost Regex 的regex_search进行遍历搜索

标签:

原文地址:http://www.cnblogs.com/liaocheng/p/4390536.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!