没什么说的,需要

#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. 异常:Injection of autowired dependencies failed; nested exception is java.lang.IllegalArgumentException

    这个异常是出现在注入配置文件中配置好的属性时报错的: Injection of autowired dependencies failed; nested exception is java.lang ...

  2. 通用Adapter设计,SparseArray+泛型+回调的使用

    看到题目,我相信聪明的各位已经有一定想法了. 一个Adapter,最简单的优化就是使用泛型,他可以省去非常多的代码,不过在此之上,我们还可以继续优化,优化他的好基友是:ViewHolder. 在过去, ...

  3. Android开发之漫漫长途 Ⅵ——图解Android事件分发机制(深入底层源码)

    该文章是一个系列文章,是本人在Android开发的漫漫长途上的一点感想和记录,我会尽量按照先易后难的顺序进行编写该系列.该系列引用了<Android开发艺术探索>以及<深入理解And ...

  4. Less循环

    Less循环 在Less中,mixin可以调用它自身.通过这种递归调用,再结合Guard表达式和模式匹配,就可以写出各种循环结构.如,使用循环来创建一个网格类: .generate-columns(4 ...

  5. margin、padding单位百分比

    年前做了一个测试题 https://www.wenjuan.com/s/VjaEva/,里面有一道题目涉及到了margin和padding单位为百分比的情况.写出来记录一下以防止自己忘记. <! ...

  6. 理解defineProperty以及getter、setter

    我们常听说vue是用getter与setter实现数据监控的,那么getter与setter到底是什么东西,它与defineProperty是什么关系,平时有哪些用处呢?本文将为大家一一道来. 对象的 ...

  7. Numpy数组对象的操作-索引机制、切片和迭代方法

    前几篇博文我写了数组创建和数据运算,现在我们就来看一下数组对象的操作方法.使用索引和切片的方法选择元素,还有如何数组的迭代方法. 一.索引机制 1.一维数组 In [1]: a = np.arange ...

  8. c#统计代码行数

    小编,已经快学了两年编程了.昨天突发奇想,想统计下这些年到底写过多少行代码,于是做了一个这个小程序来统计代码行数.老规矩,先上图. 比较惭愧,写了两年只有2万多行.那我们还是进入下一项吧. 界面搭建我 ...

  9. 访问者模式(Visitor)

    访问者模式(Visitor) 访问者模式把数据结构和作用于结构上的操作解耦合,使得操作集合可相对自由地演化.访问者模式适用于数据结构相对稳定算法又易变化的系统.因为访问者模式使得算法操作增加变得容易. ...

  10. Android破解学习之路(一)——简单的登录破解

    最近突然心血如潮开始学了Android破解,初入门,便是将经验记录下来. 准备工作: 1.一个登录简单APP 在我们破解之前,我们需要做一个简单的登录APP,输入相应的账号与密码便是弹出登录成功的对话 ...