龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > VC开发 >

一种简单的批分字符串的办法

时间:2009-12-30 15:42来源:未知 作者:admin 点击:
分享到:
一个小技巧,权当对Great Boost的致敬。 批分的具体规则: 电话号码或者其他的什么,都可以以下列四种符号分隔: 分号,如:1391067;62963517,或者1391067;62963;。 逗号,如:1391067,6296351

  一个小技巧,权当对Great Boost的致敬。

  批分的具体规则:

  电话号码或者其他的什么,都可以以下列四种符号分隔:

  分号,如:1391067;62963517,或者1391067;62963;。

  逗号,如:1391067,62963517,或者1391067,62963,。

  中文分号,如:1391067;62963,或者1391067;629637;。

  中文逗号,如:1391067,62963,或者1391067,629617,。

  也可以混合这四种符号,如:

  1391067,6617;62980;1234,5678;9900,0099;

。诸如此类。

  这种方式的批分,可以用boost库的tokenizer很容易的做到。

  批分代码:


 #include <boost/tokenizer.hpp>
#include <string>

...

std::string _sTokenFaxNumber("629780;010620,01091293;1234,5678;8989");      

       typedef boost::tokenizer<boost::char_separator<char> >

                            tokenizer;

    // 批发的分隔符号,枚举各种符号:

       boost::char_separator<char> sep(";,;,");

       tokenizer tokens(_sTokenFaxNumber, sep);

       tokenizer::const_iterator itBegin  = tokens.begin();

       tokenizer::const_iterator itEnd    = tokens.end();

       tokenizer::iterator       tok_iter;

       for (tok_iter = itBegin;

               tok_iter != itEnd;

               ++tok_iter)

       {

              _bstr_t bstrSingleFax((*tok_iter).c_str());

       }

收藏文章
表情删除后不可恢复,是否删除
取消
确定
图片正在上传,请稍后...
评论内容为空!
还没有评论,快来抢沙发吧!
按钮 内容不能为空!
立刻说两句吧! 查看0条评论
精彩图集

赞助商链接