关于boost里面的string

#include <boost/algorithm/string.hpp>

首先是盘点子串是否是父串的一个子串。

如下所示:

    std::string str("I Don't Know.
");
    std::cout << boost::to_upper_copy(str);
    std::cout << str ;
    boost::to_lower(str);
    std::cout << str;
    std::string str("Power Bomb");
    if (boost::iends_with(str, "bomb"))
    {
        std::cout << "bomb
";
    }
    if (!boost::ends_with(str, "bomb"))
        std::cout << "no bomb
" ;
    if (boost::starts_with(str, "Pow"))
        std::cout << "start Pow" << std::endl;
    if (boost::contains(str, "er"))
        std::cout << "contains er
";
    std::string str2 = boost::to_lower_copy(str);
    if (boost::iequals(str, str2))
        std::cout << "iequal" << std::endl;
    std::string str3("power suit");
    if (boost::lexicographical_compare(str, str3))
    {
        std::cout << "litter
";
    }
    if (boost::all(str2.substr(0, 5), boost::is_lower()))
        std::cout << "is low" << std::endl;
View Code

在这里有各种的查找和判断是否相等,如果前面加i说明是没有计较大小写。

还有一个很长的函数lexicographical_compare,该函数是判断左边的字符串是否小于右边的字符串。

boost::all(str2.substr(0, 5), boost::is_lower())

这个是判断all函数的第一个参数是否全部是小写的,如果是返回true

接下去是这个去除字符串头尾指定的字符的trim函数。如果不写if则默认是删除空格。如果有if责判断去除特定的字符。也可以删除多个特定的字符。如:boost::trim_copy_if(str2, boost::is_punct()||boost::is_digit())  去除符号和数字,并通过拷贝返回去,对str2不做改变。

对于erase和replace这两个函数也是差不多的道理,

std::cout << boost::ierase_all_copy(str, "samus");
std::cout << boost::replace_nth_copy(str, "l", 1, "L");
std::cout << boost::erase_tail_copy(str, 8);

接下来这个是关于分割的各种方式

加#include <boost/assign.hpp>

    std::string str = "Samus,Link.Zelda::Mario-Luigi+zelda";
    std::deque<std::string> d;
    boost::ifind_all(d, str, "zELDA");
    for (BOOST_AUTO(pos, d.begin()); pos != d.end(); ++pos)
    {
        std::cout << "[" << *pos << "]" ;
    }
    std::cout << std::endl;
    std::list<boost::iterator_range<std::string::iterator> > l;
    boost::split(l, str, boost::is_any_of(",.:-+"));
    for (BOOST_AUTO(pos, l.begin()); pos != l.end(); ++pos)
    {
        std::cout << "[" << *pos << "]" ;
    }
    std::cout << std::endl;
    l.clear();
    boost::split(l, str, boost::is_any_of(".:-"), boost::token_compress_on);
    for (BOOST_AUTO(pos, l.begin()); pos != l.end(); ++pos)
    {
        std::cout << "[" << *pos << "]";
    }
    std::cout << std::endl;
View Code

在分割的时候可以有多个字符来做个分隔符。并把分割后的字符串存储到一个容器中。如上面代码所示。

这里要提的一个是:boost::token_compress_on   使能压缩和另一个boost::token_compress_off的使能不压缩即在两个分隔符连在一起的时候如果使能压缩,则只看成是一个分隔符。

有分割就有合并

    std::vector<std::string> v = boost::assign::list_of("Samus")("Link")("Zelda")("Mario");
    std::cout << boost::join(v, "+") << std::endl;

    struct is_contains_a
    {
        bool operator()(const std::string &x)
        {
            return boost::contains(x, "a");
        }
    };
    std::cout << boost::join_if(v, "**", is_contains_a());
View Code
原文地址:https://www.cnblogs.com/cxiaoln/p/3375304.html