来自: https://blog.csdn.net/huang_xw/article/details/8276123

函数声明:

  1.  
    template<typename Range1T, typename Range2T>
  2.  
    iterator_range find_first(Range1T & Input, const Range2T & Search);
  3.  
    template<typename Range1T, typename Range2T>
  4.  
    iterator_range find_last(Range1T & Input, const Range2T & Search);
  5.  
    template<typename Range1T, typename Range2T>
  6.  
    iterator_range find_nth(Range1T &Input, const Range2T & Search, int Nth);
  7.  
    template<typename RangeT>
  8.  
    find_head(RangeT &Input, int N);
  9.  
    template<typename RangeT>
  10.  
    find_tail(RangeT & Input, int N);

例子:

  1.  
    // find_first:【1】查找字符串在输入中第一次出现的位置。
  2.  
    // find_last: 【2】查找字符串在输入中最后一次出现的位置。
  3.  
    // find_nth: 【3】查找字符串在输入中的第n次(从0开始计数)出现的位置。
  4.  
    // find_head: 【4】取一个字符串开头N个字符的字串,相当于substr(0,n);
  5.  
    // find_tail: 【5】取一个字符串末尾N个字符的字串。
  6.  
    void test_string_find_string()
  7.  
    {
  8.  
    std::string str1("a1234_first_nth_first_nth_");
  9.  
    boost::iterator_range<std::string::iterator> ir;
  10.  
     
  11.  
    // find_first与ifind_first(不区分大小写,其它同find_first)
  12.  
    ir = boost::find_first(str1, "first");
  13.  
    // 1. 通过iterator_range构建字符串
  14.  
    assert(std::string(ir.begin(), ir.end()) == "first");
  15.  
    // 2. 查看搜索到的字符串所在位置
  16.  
    assert(ir.begin() - str1.begin() == 6 && ir.end() - str1.begin() == 6 + 5);
  17.  
    // 3. 利用iterator_range处理搜索到的字符串
  18.  
    boost::to_upper(ir);
  19.  
    assert(str1 == "a1234_FIRST_nth_first_nth_");
  20.  
    boost::to_lower(ir);
  21.  
    assert(str1 == "a1234_first_nth_first_nth_");
  22.  
     
  23.  
    // find没有找到的情况
  24.  
    ir = boost::find_first(str1, "no");
  25.  
    assert(ir.empty()); // 不存在
  26.  
    assert(std::string(ir.begin(), ir.end()).empty()); // 不存在,仍可构建一个string
  27.  
    std::ostringstream osstr;
  28.  
    osstr << boost::find_first(str1, "_first_");
  29.  
    assert(osstr.str() == "_first_");
  30.  
    }

find_token的函数声明

  1.  
    template<typename RangeT, typename PredicateT>
  2.  
    iterator_range< typename range_iterator< RangeT >::type >
  3.  
    find_token(RangeT & Input, PredicateT Pred,
  4.  
    token_compress_mode_type eCompress = token_compress_off);

find_token的例子

  1.  
    void test_string_find_token()
  2.  
    {
  3.  
    using namespace boost;
  4.  
     
  5.  
    std::string str1("ab1234_first_nth_first_nth_");
  6.  
    iterator_range<std::string::iterator> ir;
  7.  
     
  8.  
    ir = find_token(str1, is_any_of("irfst"));
  9.  
    assert(std::string(ir.begin(), ir.end()) == "f");
  10.  
     
  11.  
    ir = find_token(str1, is_any_of("xfirts"), token_compress_off);
  12.  
    assert(std::string(ir.begin(), ir.end()) == "f");
  13.  
     
  14.  
    ir = find_token(str1, is_any_of("irfst"), token_compress_on);
  15.  
    assert(std::string(ir.begin(), ir.end()) == "first");
  16.  
     
  17.  
    ir = find_token(str1, is_any_of("fitr "), token_compress_on);
  18.  
    assert(std::string(ir.begin(), ir.end()) == "fir");
  19.  
     
  20.  
    ir = find_token(str1, is_lower(), token_compress_on);
  21.  
    assert(std::string(ir.begin(), ir.end()) == "ab");
  22.  
    }

find_regex的例子

    1.  
      // 注意加上头文件
    2.  
      // #include <boost/algorithm/string/regex.hpp>
    3.  
      // find_regex, find_all_regex
    4.  
      void test_string_find_regex()
    5.  
      {
    6.  
      using namespace boost;
    7.  
       
    8.  
      std::string str1("ab1234_first_nth_first_nth_");
    9.  
      iterator_range<std::string::iterator> ir;
    10.  
      regex rx("b[0-9]+_");
    11.  
       
    12.  
      ir = find_regex(str1, rx);
    13.  
      assert(std::string(ir.begin(), ir.end()) == "b1234_");
    14.  
       
    15.  
      std::string str2("b1_b22_b333_b4444");
    16.  
      std::vector<std::string> tokens;
    17.  
      find_all_regex(tokens, str2, rx);
    18.  
      assert(tokens.size() == 3);
    19.  
      assert(tokens[0] == "b1_");
    20.  
      assert(tokens[1] == "b22_");
    21.  
      assert(tokens[2] == "b333_");
    22.  
       
    23.  
      // 网络上找到的另一个例子
    24.  
      std::string value = "123a1cxxxxa56c";
    25.  
      regex pattern("a[0-9]+c");
    26.  
      iterator_range<std::string::iterator> find_result;
    27.  
      find_result = algorithm::find_regex(value, pattern);
    28.  
      assert(!find_result.empty());
    29.  
       
    30.  
      std::vector<std::string> results;
    31.  
      find_all_regex(results, value, pattern);
    32.  
      assert("a1c" == results[0]);
    33.  
      assert("a56c" == results[1]);
    34.  
      assert(!results.empty());
    35.  
       
    36.  
      value = "10.10.10.10 1.1.1.1";
    37.  
      boost::regex ip_pattern("(\\d{1, 3}.){3}\\d{1, 3}");
    38.  
      find_all_regex(results, value, ip_pattern);
    39.  
      assert("10.10.10.10" == results[0]);
    40.  
      assert("1.1.1.1" == results[1]);
    41.  
      assert(!results.empty());
    42.  

【Boost】boost::string_algo详解2——find相关函数的更多相关文章

  1. [转] boost::function用法详解

    http://blog.csdn.net/benny5609/article/details/2324474 要开始使用 Boost.Function, 就要包含头文件 "boost/fun ...

  2. boost::function用法详解

    要开始使用 Boost.Function, 就要包含头文件 "boost/function.hpp", 或者某个带数字的版本,从 "boost/function/func ...

  3. boost::fucntion 用法详解

    转载自:http://blog.csdn.net/benny5609/article/details/2324474 要开始使用 Boost.Function, 就要包含头文件 "boost ...

  4. boost库asio详解1——strand与io_service区别

    namespace { // strand提供串行执行, 能够保证线程安全, 同时被post或dispatch的方法, 不会被并发的执行. // io_service不能保证线程安全 boost::a ...

  5. Boost::bind使用详解

    1.Boost::bind 在STL中,我们经常需要使用bind1st,bind2st函数绑定器和fun_ptr,mem_fun等函数适配器,这些函数绑定器和函数适配器使用起来比较麻烦,需要根据是全局 ...

  6. Boost::split用法详解

    工程中使用boost库:(设定vs2010环境)在Library files加上 D:\boost\boost_1_46_0\bin\vc10\lib在Include files加上 D:\boost ...

  7. 【Boost】boost库asio详解5——resolver与endpoint使用说明

    tcp::resolver一般和tcp::resolver::query结合用,通过query这个词顾名思义就知道它是用来查询socket的相应信息,一般而言我们关心socket的东东有address ...

  8. boost::algorithm用法详解之字符串关系判断

    http://blog.csdn.net/qingzai_/article/details/44417937 下面先列举几个常用的: #define i_end_with boost::iends_w ...

  9. 【Boost】boost库asio详解3——io_service作为work pool

    无论如何使用,都能感觉到使用boost.asio实现服务器,不仅是一件非常轻松的事,而且代码很漂亮,逻辑也相当清晰,这点上很不同于ACE.使用io_service作为处理工作的work pool,可以 ...

随机推荐

  1. 数据特征分析:3.统计分析 & 帕累托分析

    1.统计分析 统计指标对定量数据进行统计描述,常从集中趋势和离中趋势两个方面进行分析 集中趋势度量 / 离中趋势度量 One.集中趋势度量 指一组数据向某一中心靠拢的倾向,核心在于寻找数据的代表值或中 ...

  2. 使用entitiy

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.D ...

  3. Python编程基础[条件语句if 循环语句 for,while](二)

    ython条件语句是通过一条或多条语句的执行结果(True或者False)来决定执行的代码块. 可以通过下图来简单了解条件语句的执行过程: if 判断条件: 执行语句……else: 执行语句…… x= ...

  4. maven聚合工程无法install

    对于maven聚合工程,有时候执行maven命令进行mvn clean install时会出一些莫名奇妙的错误: 一直报告找不到符号,仔细看了项目源代码也不知道是什么原因.首先确保项目所在路径为英文路 ...

  5. 【官档整理】Visual Studio 2017 VS2017 中文离线安装包下载

    [官档整理]Visual Studio 2017 VS2017 中文离线安装包下载 转 https://blog.csdn.net/fromfire2/article/details/81104648 ...

  6. 生日蛋糕 POJ - 1190 (搜索+剪枝)

    7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体. 设从下往上数第i(1 <= i <= M)层蛋糕是半径为Ri, 高度为Hi的圆柱.当 ...

  7. Trace 2018徐州icpc网络赛 (二分)(树状数组)

    Trace There's a beach in the first quadrant. And from time to time, there are sea waves. A wave ( xx ...

  8. Linux学习之RPM包管理-rpm命令管理(十六)

    Linux学习之RPM包管理-rpm命令管理 目录 简介 RPM包依赖性 包全名与包名 rpm软件包安装 rpm软件包卸载 升级降级rpm软件包 rpm软件包的查询 rpm软件包校验 简介 RPM是R ...

  9. uni-app — 一套前端开发跨平台应用的终极解决方案

    uni-app 是一个使用 Vue.js 开发跨平台应用的前端框架,开发者编写一套代码,可编译到iOS.Android.H5.小程序等多个平台. 今天有空就来介绍一下uni-app这个能够跨平台开发, ...

  10. Redis自学笔记:4.2进阶-过期时间

    4.2过期时间 **4.2.1命令介绍* 在redis中使用 expire 命令设置一个键的过期时间后redis会自动删除它. expire key seconds (seconds单位是秒,必须是整 ...