0
vector<string> SplitString (string aString,char *sep) 
{  
  vector<string> vec;
  char * cstr,*val,*p;
  string str = aString;
  cstr = new char [str.size()+1];
  strcpy (cstr, str.c_str());
  p=strtok (cstr,sep);
  while(p!=NULL)
  {    
    vec.push_back(p);  
    p=strtok(NULL,sep);

  }delete[] cstr;return vec; }

这是我的字符串拆分代码。我发送了以下字符串以使用分隔符“&”进行拆分

"f0=fname0&l0=lname0&f1=fname1&l1=lname1&f2=fname2&l2=lname2&f3=&l3="。

我在向量中得到了如下结果。

f0=fname0 l0=lname0 f1=fname1 l1=lname1 f2=fname2 l2=lname2 f3= l3=

现在我再次发送带有分隔符'='的结果字符串。它与“l2 = lname2”一起工作正常。但是对于 "f3=" 和 "l3=" 我的分隔符在字符串的最后一个位置。所以我找不到该值是否为 null 。我想知道值('=' 的左侧是名称,右侧是值)是否为空。我该如何检查这个。

4

2 回答 2

0

提升呢?我认为这是分割字符串的最简单方法。

#include <algorithm>
#include <iterator>
#include <boost/algorithm/string.hpp>
using namespace std;
using namespace boost;

int main()
{
    string s("f0=fname0&l0=lname0&f1=fname1&l1=lname1&f2=fname2&l2=lname2&f3=&l3=");

    vector<string> v1;    
    split(v1, s, is_any_of("&"), token_compress_on); 
    copy(v1.begin(), v1.end(), ostream_iterator<string>(cout, "\n"));    

    for (auto i : v1) {
        vector<string> v2;
        split(v2, i, is_any_of("="), token_compress_on); 

        copy(v2.begin(), v2.end(), ostream_iterator<string>(cout, "\n===\n"));
    }
}
于 2012-08-27T06:17:01.853 回答
0

检查您要标记的字符串的最后一个字符是否实际上是分隔符本身。

while (p != NULL && p[strlen(p) - 1] != *sep)


编辑:根据您的评论,然后在对字符串进行标记之前,我将使用它来修改它,string::find并将string::replace出现的“=&”替换为“=hi&”,并将终止的“=”替换为“=hi”。这样,您将避免尴尬的解析。

此外,您不需要两次标记化,因为strDelimit参数 ofstrtok可以是“&=”(一次传递中的两个定界符)。

于 2012-08-27T06:22:20.653 回答