[Boost]一种简单的批分字符串的办法 (转)

本文介绍了一种使用Boost库中的tokenizer进行批量字符串分割的方法。通过定义分隔符包括中英文的逗号及分号,可以轻松地对包含这些特殊字符的字符串进行分割处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[Boost]一种简单的批分字符串的办法 (转)[@more@]

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

批分的具体规则:

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

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

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

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

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

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

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

。诸如此类。

 XML:namespace prefix = o ns = "urn:schemas-microsoft-com:Office:office" />

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

批分代码:

#include
#include

...

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

  typedef boost::tokenizer<:char_separator> >

  tokenizer;

 

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

  boost::char_separator 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());

  }

 


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752043/viewspace-960549/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10752043/viewspace-960549/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值