MFC中几种常用的字符串分割方法

本文总结了几种常用的MFC字符串分割的方法,以方便自己以后查阅,也希望能帮助到有需要帮助的人。

1、CString 自带的函数Tokenize

1
CStringT Tokenize( _In_ PCXSTR pszTokens, _Inout_ int & iStart ) const

功能介绍:从iStart位置取出字符串中含pszTokens分割符间的内容;istart是开始分割的位置,一般设为0,下面是一段运用实例:

1
2
3
4
5
6
7
8
9
10
11
12
vector<CString> SplitCString(CString strSource, CString ch)
{
       vector <CString> vecString;
       int iPos = 0;
       CString strTmp;
       strTmp = strSource.Tokenize(ch,iPos);
     while (strTmp.Trim() != _T( "" ))
     {
         vecString.push_back(strTmp);
         strTmp = strSource.Tokenize(ch,iPos);
     }
}

上述函数将字符串strSource按照字符串ch进行分割,分割得带的子字符串放到vector中。其中函数中的iPos是不断变化的,而Tokenize本身不会改变源字符串。

2、char *strtok(char s[], const char *delim);

功能介绍:分解字符串为一组字符串。s为要分解的字符串,delim为分隔符字符串。首次调用时,s指向要分解的字符串,之后再次调用要把s设成NULL。从s开头开始的一个个被分割的串。当查找不到delim中的字符时,返回NULL。所有delim中包含的字符都会被滤掉,并将被滤掉的地方设为一处分割的节点。下面是一段运用实例。

1
2
3
4
5
6
7
8
9
10
11
12
13
vector<CString> SplitCString(CString strSource, char ch)
{
      vector<CString> vecString;
      CString strTmp= strtok (( LPSTR )( LPCTSTR )strSource,ch); //(LPSTR)(LPCTSTR)将CString转char*
     while (1)
           {   
          strTmp= strtok (NULL,ch);
         if (strTmp==_T( "" ))             
             break ;
          strTmp.TrimLeft();
                 vecString.push_back(strTmp);
     }
}

与第一种方法有一点区别,上述函数第二个参数是char型的,第一种方法的第二个可以是CString型的,但是实现的功能相似。

3、BOOL AFXAPI AfxExtractSubString ( CString& rString, LPCTSTR lpszFullString, int iSubString, TCHAR chSep = ‘\n’);

功能介绍:可用于从特定源字符串中提取子字符串。如果函数成功提取了该子字符串中提供的索引,返回TRUE 否则返回FALSE。其中
//   rString 对CString将得到一个单独的子字符串的对象。
//    lpszFullString 待分割的字符串。
//    iSubString 提取的子字符串的序号,从0开始。假如你想提取第3段,该参数就输入2
//    chSep 用于分割的字符,默认的是’\n’。
下面是一段运用实例

1
2
3
4
5
6
7
8
9
10
11
12
vector<CString> SplitCString(CString strSource, char ch)
{  
   CString strTmp;
   vector<CString> vecString;
   int iPos=0;
     while (AfxExtractSubString(strTmp,strSource,iPos,ch))
     {
         iPos++;
         vecString.push_back(strTmp);
     }  
  return vecString;
}

特别注意:strtok在分割的时候将分割符改变成‘/0’了,所以这个函数会修改源字符串,分割符不会包含在分割出来的字符串中,strtok允许多分割字符,比如空格+逗号表示为‘ ,’,还有一点需要注意的是如果被分割的字符第一个是分割符,那么该字符会被忽略掉。如果出现连续的分隔符,那么也会忽略掉,比如字符串1|2||||3,用strtok来分割将得到1 2 3,但是如果用AfxExtractSubString,得到将会是1 2 空字符串 空字符串 空字符串 3,需求不同选择不同的函数。

4、利用CString  Find函数自己分割字符串

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
vector<CString> SplitCString(CString strSource, char ch)
{  
     CString strTmp;  
         vector<CString> vecString;    
     int n=-1;
         n=strSource.Find(ch)
        
     while (n!=-1)
     {
               strTmp=strSource.Left(n) //这里根据需要判断是否需要分隔符        
           vecString.push_back(strTmp);
               strSource=strsource.left(strSource.Getlenth-n+1)
               n=strSource.Find(ch);
     }  
     return vecString;
}

这种方法功能和上述类似,使用也很灵活,可以根据自己需要分割字符串。

  • 13
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MFC解析JSON字符串,可以使用第三方库如Cpp或RapidJSON。这些库提供了方便的API来解析和操作JSON数据。 下面以JsonCpp库为例,演示如何在MFC解析JSON字符串: 1. 首先,下载并导入JsonCpp库到你的MFC项目。你可以从官方网站(https://github.com/open-source-parsers/jsoncpp)下载源代码,并将其添加到你的项目。 2. 在需要解析JSON的地方,包含JsonCpp头文件: ```cpp #include <json/json.h> ``` 3. 创建一个Json::Value对象来表示解析后的JSON数据,并使用Json::Reader对象来解析JSON字符串: ```cpp Json::Value root; // 用于存储解析后的JSON数据 Json::Reader reader; std::string jsonStr = "{\"name\":\"John\",\"age\":30,\"city\":\"New York\"}"; // 示例JSON字符串 // 解析JSON字符串 bool parsingSuccessful = reader.parse(jsonStr, root); if (!parsingSuccessful) { // 解析失败,处理错误 CString errorMsg = CString(reader.getFormattedErrorMessages().c_str()); AfxMessageBox(errorMsg); return; } // 解析成功,可以访问和操作解析后的JSON数据 std::string name = root["name"].asString(); int age = root["age"].asInt(); std::string city = root["city"].asString(); ``` 在上述代码,我们创建了一个名为root的Json::Value对象存储解析后的JSON数据。然后,我们使用Json::Reader对象的parse()函数来解析JSON字符串,该函数会返回一个布尔值来指示解析是否成功。如果解析失败,我们可以使用reader.getFormattedErrorMessages()函数获取错误消息,并进行相应的处理。 如果解析成功,我们可以使用Json::Value对象来访问和操作解析后的JSON数据。在示例,我们通过root对象访问了"name"、"age"和"city"字段,并将其转换为对应的数据类型。 希望这个示例能帮助你在MFC解析JSON字符串。记得根据你的实际情况调整代码,并根据需要处理解析失败的情况。如果有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值