我一直在寻找 boost::tokenizer,我发现文档非常薄。是否可以让它标记一个字符串,例如“dolphin--monkey--baboon”,并使每个单词都成为一个标记,以及每个双破折号一个标记?从示例中,我只看到允许使用单个字符分隔符。对于更复杂的分隔符,库是否不够先进?
			
			8782 次
		
4 回答
            10        
        
		
使用 iter_split 允许您使用多个字符标记。下面的代码将产生以下内容:
  dolphin 
  mon-key 
  baboon
#include <iostream>
#include <boost/foreach.hpp>
#include <boost/algorithm/string.hpp>
#include <boost/algorithm/string/iter_find.hpp>
    // code starts here
    std::string s = "dolphin--mon-key--baboon";
    std::list<std::string> stringList;
    boost::iter_split(stringList, s, boost::first_finder("--"));
    BOOST_FOREACH(std::string token, stringList)
    {    
        std::cout << token << '\n';  ;
    }
    于 2009-10-07T03:16:49.843   回答
    
    
            2        
        
		
我知道这个主题已经很老了,但是当我搜索“boost tokenizer by string”时,它会显示在谷歌的顶部链接中
所以我将添加我的 TokenizerFunction 变体,以防万一:
class FindStrTFunc
{
public:
    FindStrTFunc() : m_str(g_dataSeparator)
    {
    }
    bool operator()(std::string::const_iterator& next,
        const std::string::const_iterator& end, std::string& tok) const
    {
        if (next == end)
        {
            return false;
        }
        const std::string::const_iterator foundToken =
            std::search(next, end, m_str.begin(), m_str.end());
        tok.assign(next, foundToken);
        next = (foundToken == end) ? end : foundToken + m_str.size();
        return true;
    }
    void reset()
    {
    }
private:
    std::string m_str;
};
在我们可以创建之后
boost::tokenizer<FindStrTFunc> tok("some input...some other input");
并使用,就像通常的 boost tokenizer
于 2012-01-06T20:26:51.297   回答
    
    
            1        
        
		
一种选择是尝试 boost::regex。不确定与自定义标记器相比的性能。
std::string s = "dolphin--monkey--baboon";
boost::regex re("[a-z|A-Z]+|--");
boost::sregex_token_iterator iter(s.begin(), s.end() , re, 0);
boost::sregex_token_iterator end_iter;
while(iter != end_iter)
{
    std::cout << *iter << '\n';
    ++iter;
}
    于 2009-08-09T21:56:56.590   回答
    
    
            0        
        
		
看起来您需要编写自己的TokenizerFunction来做您想做的事情。
于 2009-08-09T20:56:44.137   回答