没什么说的,需要

#include<boost/algorithm/string.hpp>

1.大小写转换

    std::string s("test string");

    boost::to_upper(s);//转换为大写
boost::to_lower(s);//转换为小写 std::string str1=boost::to_lower_copy(s);//小写转换并赋值
std::string str2=boost::to_upper_copy(s);//大写转换并赋值
    std::array<string, 3> k = {"hello", "world", "123"};
std::cout << join(k, "-"); //输出结果为: hello-world-123

2.分割与合并字符串

    std::string s("test stringa-test stringb-test stringc");
std::vector<std::string> sv;
boost::split(sv,s,boost::is_any_of("-"),boost::token_compress_on);
//Now,sv={"test stringa","test stringb","test stringc"};

3.去掉字符串两边空格

    std::string s("      test string      ");
boost::trim_left(s);//去掉字符串左边空格
boost::trim_right(s);//去掉字符串右边空格
//现在s="test string"
//boost::trim_left_copy(s)和boost::trim_right_copy(s)表示去掉后赋值

trim_left_copy_if() 将字符串开头的符合我们提供的“谓词”的特定字符去掉,并且赋值给另一个字符串

 string str1(" hello world! ");
string str2;
str2 = trim_left_copy_if(str1, NotH); // str2 == "ello world! "

总结一下就是凡是有copy就是指向后赋值,有if就判断谓词

3.谓词

    std::string s("test string");
boost::starts_with("test");//判断字符串是否以一个字符串开始,返回bool
    std::string a("sss");
std::string b("sss");
boost::equal(a,b);//判断字符串是否完全匹配
    std::string s("test string");
boost::contains("te");//判断字符串是否含有某字符串
boost::ends_with("ing");//判断字符串是否以另一个字符串结尾;
// boost::iends_with()同上只是不区分大小写

all()判断字符串中的所有字符是否全部满足这个谓词

    std::string s("test string");

    bool str_equal(const std::string p){
if(boost::equal(p,"test string"))
return true;
return false;
}
boost::all(s,str_equal);

4.查找字符串

这里复制粘贴一段

find_first() 从头查找字符串中的子字符串,返回这个子串在原串中的iterator_range迭代器

 Example:

 char ToUpper(char &ch)

 char ToUpper(char &ch)

 {

  if(ch <= 'z' && ch >= 'a')

   return ch + 'A'-'a';

  else

   return ch;

 }

 ...

 string str1("hello dolly!");

 iterator_range<string::iterator> result = find_first(str1,"ll");

 transform( result.begin(), result.end(), result.begin(), ToUpper ); // str1 == "heLLo dolly!"

ifind_first() 从头查找字符串中的子字符串,返回这个子串在原串中的iterator_range迭代器(不区分大小写)

find_last() 从尾查找字符串中的子字符串,返回这个子串在原串中的iterator_range迭代器

ifind_last() 从尾查找字符串中的子字符串,返回这个子串在原串中的iterator_range迭代器(不区分大小写)

find_nth() 找到第n个匹配的子串(计算从0开始)

 Example:

 string str1("hello dolly!");

 iterator_range<string::iterator> result = find_nth(str1,"ll", 1);

 transform( result.begin(), result.end(), result.begin(), ToUpper ); // str1 == "hello doLLy!"

ifind_nth() 找到第n个匹配的子串(计算从0开始)(不区分大小写)

find_head() 找到字符串的前n个字节

 Example:

 string str1("hello dolly!");

 iterator_range<string::iterator> result = find_head(str1,5);

 transform( result.begin(), result.end(), result.begin(), ToUpper ); // str1 == "HELLO dolly!"

find_tail() 找到字符串的后n个字节

find_token() 找到符合谓词的串

 Example:

 char Add1(const char &ch)

 {

  return ch+1;

 }

 ...

 string str1("hello 1 world!");

 iterator_range<string::iterator> result = find_token(str1,is_123digit);

 transform( result.begin(), result.end(), result.begin(), Add1 ); // str1 == "hello 2 world!");

10 find_regex() 匹配正则表达式

 Example:(等稍候了解了boost的正则表达式后再给出)

11 find() 使用自己写的查找函数

 Example:

 iterator_range<string::iterator>

 MyFinder1( std::string::iterator begin, std::string::iterator end )

 {

  std::string::iterator itr;

  for(itr = begin;itr!=end;itr++)

  {

   if((*itr) == '1')

   {

    std::string::iterator preitr = itr;

    iterator_range<string::iterator> ret(preitr, ++itr);

    return ret;

   }

  }

  return iterator_range<string::iterator>();

 } // boost自己也提供了很多Finder

 ...

 string str1("hello 1 world!");

 iterator_range<string::iterator> result = find(str1,MyFinder1);

 transform( result.begin(), result.end(), result.begin(), Add1 ); // str1 == "hello 2 world!");

5.替换/删除字符串

replace_first() 从头找到第一个匹配的字符串,将其替换为给定的另外一个字符串

 Example:

 string str1("hello world!");

 replace_first(str1, "hello", "Hello"); // str1 = "Hello world!"

replace_first_copy()  从头找到第一个匹配的字符串,将其替换为给定的另外一个字符串,并且赋

值给另一个字符串

 Example:

 string str1("hello world!");

 string str2;

 str2 = replace_first_copy(str1, "hello", "Hello"); // str2 = "Hello world!"

ireplace_first()  从头找到第一个匹配的字符串,将其替换为给定的另外一个字符串(不区分大小写

)

ireplace_first_copy()  从头找到第一个匹配的字符串,将其替换为给定的另外一个字符串,并且赋

值给另一个字符串(不区分大小写)

erase_first()   从头找到第一个匹配的字符串,将其删除

 Example:

 string str1("hello world!");

 erase_first(str1, "llo"); // str1 = "He world!"

erase_first_copy() 从头找到第一个匹配的字符串,将其删除,并且赋值给另一个字符串

 Example:

 string str1("hello world!");

 string str2;

 str2 = erase_first_copy(str1, "llo"); // str2 = "He world!"

ierase_first()  从头找到第一个匹配的字符串,将其删除(不区分大小写)

8 ierase_first_copy() 从头找到第一个匹配的字符串,将其删除,并且赋值给另一个字符串(不区分大

小写)

// 与上面类似,不过是从字符串尾开始替换

9 replace_last()

10 replace_last_copy()

11 ireplace_last()

12 ireplace_last_copy()

13 erase_last()

14 erase_last_copy()

15 ierase_last()

16 ierase_last_copy()

boost::algorithm(字符串算法库)的更多相关文章

  1. boost::format(字符串格式化库)

    这段时间学习boost库的使用,撰文一方面留以备用,另一方面就是shared精神. format主要是用来格式化std::string字符串以及配合std::cout代替C语言printf() 使用f ...

  2. boost字符串算法

    boost::algorithm简介 2007-12-08 16:59 boost::algorithm提供了很多字符串算法,包括: 大小写转换: 去除无效字符: 谓词: 查找: 删除/替换: 切割: ...

  3. C++神奇算法库——#include<algorithm>

    算法(Algorithm)为一个计算的具体步骤,常用于计算.数据处理和自动推理.C++ 算法库(Algorithms library)为 C++ 程序提供了大量可以用来对容器及其它序列进行算法操作的函 ...

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

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

  5. C++ algorithm算法库

    C++ algorithm算法库 Xun 标准模板库(STL)中定义了很多的常用算法,这些算法主要定义在<algorithm>中.编程时,只需要在文件中加入#include<algo ...

  6. 字符串算法(string_algorithm)

    format 作用 格式化输出对象,可以不改变流输出状态实现类似于printf()的输出 头文件 #include <boost/format.hpp> using namespace b ...

  7. OpenSSL密码算法库: MD5示例小程序

    OpenSSL http://www.openssl.org/ OpenSSL整个软件包大概可以分成三个主要的功能部分:密码算法库.SSL协议库以及应用程序.OpenSSL 的密码算法库包含多种加密算 ...

  8. C++的字符串格式化库

    这里向大家介绍一个C++的字符串格式化库,叫cpptempl,这个库支持对字符串格式的条件,循环,变量插入.看上去很不错,只不过其是基于boost库的. 下面是一个例子: 1 2 3 4 5 6 7 ...

  9. boost split字符串

    boost split string , which is very convenience #include <string> #include <iostream> #in ...

随机推荐

  1. android sdk manager 国内镜像

    //东软信息学院 mirrors.neusoft.edu.cn 80   //北京化工大学 ubuntu.buct.edu.cn/ubuntu.buct.cn 80   //中国科学院开源协会 mir ...

  2. 【转】javascript中的LHS与RHS

    原文链接:http://www.cnblogs.com/yangxiaoguai132/p/5064625.html 最近在学习javascript过程中,接触了LHS与RHS的概念,刚开始的时候有点 ...

  3. UnityShader-菲涅尔反射(Fresnel Reflection)

    菲涅耳公式(或菲涅耳方程),由奥古斯丁·让·菲涅耳导出.用来描述光在不同折射率的介质之间的行为.由公式推导出的光的反射称之为"菲涅尔反射".菲涅尔公式是光学中的重要公式,用它能解释 ...

  4. 简单的Spring Web工程跳转且传参Demo

    jdbc.properties jdbc.driverClassName=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://192.168.1.136:3306/ ...

  5. js 数组去重复的方法

    数组去重复是js中常用的方法,归纳了四种如下: 1. for + indexOf  去重复 var arr = [3,5,5,4,1,1,2,3,7,2,5]; var target = []; fo ...

  6. Python创建二维数组(关于list的一个小坑)

    0.目录 1.遇到的问题 2.创建二维数组的办法 3.1 直接创建法 3.2 列表生成式法 3.3 使用模块numpy创建 1.遇到的问题 今天写Python代码的时候遇到了一个大坑,差点就耽误我交作 ...

  7. NOIP2017 小凯的疑惑

    题目描述 小凯手中有两种面值的金币,两种面值均为正整数且彼此互素.每种金币小凯都有 无数个.在不找零的情况下,仅凭这两种金币,有些物品他是无法准确支付的.现在小 凯想知道在无法准确支付的物品中,最贵的 ...

  8. 【练习】HTML+CSS

    作业要求1 京东首页轮播图,效果如下 <!DOCTYPE html> <html lang="en"> <head> <meta char ...

  9. webrc视频数据发送处理流程详解

  10. django同时查询两张表的数据,合并检索对象返回

    原始需求: 1.一篇文章内容分N个版块,每篇文章的版块数量不同. 2.有个文章搜索功能,需要同时搜索标题和内容. 实现思路: 1.由于每篇文章的内容版块数量不同,因此将每个文章的标题和内容分开存入2张 ...