• 关于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
  • 相关阅读:
    【代码笔记】Web-CSS-CSS伪类
    「MoreThanJava」Day 4:面向对象基础
    96年/离职8个月/拒绝华为offer/目前自由职业-记这大半年来的挣扎与迷茫
    nginx配置path_info,让codeigniter访问其它路由不是404
    Golang 与 JS 的字符串截取大同小异
    [Py] Python 的 shape、reshape 含义与用法
    微信公众号分享接口报错 "errMsg": "config:invalid url domain"
    vi以及vim打开文件中文乱码
    常见的移动端H5页面开发遇到的坑和解决办法
    CSS3 Transform 属性详解
  • 原文地址:https://www.cnblogs.com/cxiaoln/p/3375304.html
Copyright © 2020-2023  润新知