使用Boost库拆分字符串
使用Boost库拆分字符串
在日常开发中经常会遇到分割字符串的要求,boost库为我们提供了一个方便的分词器——boost::tokenizer。现在就让我们学习一下boost库的分词器。
- #include <string>
- #include <iostream>
- #include <boost/format.hpp>
- #include <boost/tokenizer.hpp>
- #include <boost/algorithm/string.hpp>
- int _tmain(int argc, _TCHAR* argv[])
- {
- // 待分割的字符串
- std::string strTag = _T("I Come from China");
- // 定义分割方式为英文逗号,中文逗号和空格,构造一个分词器,
- boost::char_separator<char> sep(" ,,");
- typedef boost::tokenizer<boost::char_separator<char> >
- CustonTokenizer;
- CustonTokenizer tok(strTag,sep);
- // 输出分割结果
- std::vector<std::string> vecSegTag;
- for(CustonTokenizer::iterator beg=tok.begin(); beg!=tok.end();++beg)
- {
- vecSegTag.push_back(*beg);
- }
- for (size_t i =0;i<vecSegTag.size();i++)
- {
- std::cout<<vecSegTag[i]<<std::endl;
- }
- // 尝试下分割中文字符
- vecSegTag.clear();
- std::string strTag2 = _T("我叫小明,你呢,今天天气不错");
- CustonTokenizer tok2(strTag2,sep);
- for(CustonTokenizer::iterator beg=tok2.begin(); beg!=tok2.end();++beg)
- {
- vecSegTag.push_back(*beg);
- }
- for (size_t i =0;i<vecSegTag.size();i++)
- {
- std::cout<<vecSegTag[i]<<std::endl;
- }
- getchar();
- return 0;
- }
|
评论暂时关闭