CString 分割并输出子字符串的问题

lwncdx 2008-09-05 12:35:25
如何写一个CString的分割函数,类似于java中的split()函数。
CString * SplitString(CString str, char split)
{
//str为待分割的CString,split为分割符如:,|或空格
}

现在我要调用这个函数把字符串“sssdf sfds jieuri lj122 98098”按空格分割成5个子字符串并输出

void printStr (CString str)//输出分割后的子字符串的函数
{

CString * strArray ;
strArray = SplitString(str,' ');
//现在我该怎么输出子字符串,因为str是任意的,所以strArray中的元素个数是不确定的,
该怎么判断数组的大小或者有更好的办法输出子字符串
}

CString str = "sssdf sfds jieuri lj122 98098";
printStr(str);// 输出的是5个子字符串
...全文
32727 20 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
20 条回复
切换为时间正序
请发表友善的回复…
发表回复
chenzhao064 2012-10-08
  • 打赏
  • 举报
回复
sscanf没有办法用于不固定的字符串呀
yel617 2012-10-08
  • 打赏
  • 举报
回复
不错,学习了
cqes123 2012-09-27
  • 打赏
  • 举报
回复
不错不错 终于找到了
力大水手 2011-07-05
  • 打赏
  • 举报
回复
AfxExtractSubString这个比较好用一点吧!!

CString str = “sssdf sfds jieuri lj122 98098”;
CString strGet(_T(""));

CStringArry strArry;

while (AfxExtractSubString(strGet, str, i++, _T(' ')))
{
strArry.Add(strGet);
}
int d = strArry.GetSize();
for (int j=0; j<d; j++)
{
MessageBox(strArry.GetAt(j));
}
d2049 2011-05-22
  • 打赏
  • 举报
回复
我刚也写了个看看。。。
CString *Split(const CString &scStr,const CString &spStr,UINT &Count)
{//获取分隔后的字符串数组
UINT pos=-1,ct=0,*Poss;
CString tmp;
Poss=new UINT[scStr.GetLength()];
do{
Poss[ct++]=pos;
pos=scStr.Find(spStr,pos+1); //从前位置+1往后查
}while((pos!=-1));
Poss[ct]=scStr.GetLength();
CString *pStrs=new CString[ct]; //存放数组
for(int i=0;i<ct;i++){
pStrs[i]=scStr.Mid(Poss[i]+1,Poss[i+1]-Poss[i]-1);
}
delete Poss;
Count=ct;
return pStrs;
}
mmqzone 2011-04-18
  • 打赏
  • 举报
回复
2楼得方法不错。。。。学习了。
DaveLee001 2010-06-30
  • 打赏
  • 举报
回复
2楼的简洁方便
kaoboluo 2009-09-04
  • 打赏
  • 举报
回复
学习了
lwncdx 2008-09-05
  • 打赏
  • 举报
回复
谢谢各位!让我受益匪浅,二楼的方法很好,splitString()函数中用了两个循环,能否只用一个循环实现
希望有更简单的实现方法。
luckyboy1979 2008-09-05
  • 打赏
  • 举报
回复
void SplitString(CString str, char split,CStringArray& strGet)
{
//str为待分割的CString,split为分割符如:, ¦或空格 strGet为输出参数,你得到的字符串存放在strGet中
int pos = -1;
pos = str.Find(split);
while(pos != -1)
{
CString strSun = "";
strSun = str.Left(pos);
strGet.Add(strSun);
str.Delete(0,pos);
pos = str.Find(split);
}
if(str != "")
{//最后剩下的字符串可能没有split这个标示,看你需要怎么处理了
//这里也把他加入到strGet中
strGet.Add(str);
}
}
假设你的输出函数是void PrintStr(CString str);
CString str = "sssdf sfds jieuri lj122 98098";
CStringArray strArray;
strArray.RemoveAll();
SplitString(str,' ',strGet);
int count = strGet.GetSize();
for(int i=0;i<count;i++)
{
PrintStr(strGet[i]);
}

不知是否符合你的要求,供参考!
zqh886 2008-09-05
  • 打赏
  • 举报
回复
CString str="sssdf sfds jieuri lj122 98098";
char *csInput;

csInput=str.GetBuffer(str.GetLength()); //提取字符串,把单词存放在数组csInput中
char seps[]= " "; //字符串以空格分隔符
char *token;

token = strtok( csInput, seps );
index=0; //全局变量
while( token != NULL ) //把提取到的单词存放到数组csEditIput中
{
csEditInput[index]=token; /* 把单词存放在数组csEditInput中" */
index++;
token = strtok( NULL, seps ); /* Get next token: */
}
yyunffu 2008-09-05
  • 打赏
  • 举报
回复
对,楼上高见,sscanf 足够搞定。

按这个做:

CString str="sssdf sfds jieuri";
char sz1[40] = "", sz2[40] = "", sz3[40] = "";
sscanf( str, "%s %s %s", sz1, sz2, sz3 );
FireBirdCN 2008-09-05
  • 打赏
  • 举报
回复
研究一下
sscanf
lizhigang34 2008-09-05
  • 打赏
  • 举报
回复
给你写了个,希望对你有帮助,扩充了下你的SplitString(CString str, char split)函数,改成了

//最后一个参数返回的是子字符串的数量
CString * SplitString(CString str, char split, int& iSubStrs);

因为你必须要知道子字符串的数量才好输出

// Test3.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include "Test3.h"


#include <tchar.h>
#define _UNICODE
#define UNICODE



#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// The one and only application object

CWinApp theApp;

using namespace std;

//最后一个参数返回的是子字符串的数量
CString * SplitString(CString str, char split, int& iSubStrs);


int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{
int nRetCode = 0;

// initialize MFC and print and error on failure
if (!AfxWinInit(::GetModuleHandle(NULL), NULL, ::GetCommandLine(), 0))
{
// TODO: change error code to suit your needs
cerr << _T("Fatal Error: MFC initialization failed") << endl;
nRetCode = 1;
}
else
{
// TODO: code your application's behavior here.
CString strHello;
strHello.LoadString(IDS_HELLO);
//cout << (LPCTSTR)strHello << endl;
}

CString str = "sssdf sfds jieuri lj122 98098";
// CString str = "sfsfsf";
CString* pStr;
int iSubStrs;
pStr = SplitString(str, ' ', iSubStrs);
//如果子字符串的数量为1
if (iSubStrs == 1)
{
//Convert CString to char
char* pCh = (LPSTR)(LPCTSTR)str;
printf("%s\n", pCh);
}
else
{
//输出所有子字符串
for (int i = 0; i < iSubStrs; i++)
{
//Convert CString to char
char* pCh = (LPSTR)(LPCTSTR)pStr[i];
printf("%s\n", pCh);
}
delete []pStr;
}

system("pause");

return nRetCode;
}


CString * SplitString(CString str, char split, int& iSubStrs)
{
int iPos = 0; //分割符位置
int iNums = 0; //分割符的总数
CString strTemp = str;
CString strRight;
//先计算子字符串的数量
while (iPos != -1)
{
iPos = strTemp.Find(split);
if (iPos == -1)
{
break;
}
strRight = strTemp.Mid(iPos + 1, str.GetLength());
strTemp = strRight;
iNums++;
}
if (iNums == 0) //没有找到分割符
{
//子字符串数就是字符串本身
iSubStrs = 1;
return NULL;
}
//子字符串数组
iSubStrs = iNums + 1; //子串的数量 = 分割符数量 + 1
CString* pStrSplit;
pStrSplit = new CString[iSubStrs];
strTemp = str;
CString strLeft;
for (int i = 0; i < iNums; i++)
{
iPos = strTemp.Find(split);
//左子串
strLeft = strTemp.Left(iPos);
//右子串
strRight = strTemp.Mid(iPos + 1, strTemp.GetLength());
strTemp = strRight;
pStrSplit[i] = strLeft;
}
pStrSplit[iNums] = strTemp;
return pStrSplit;
}

wutaihua 2008-09-05
  • 打赏
  • 举报
回复


szBuf。Format("sssdf sfds jieuri lj122 98098")
while(AfxExtractSubString(szBuf,subBuf.GetBuffer(0),nCount++," "))
{
switch (nCount)
{
case 0:
//这个时候subBuf 为sssdf
break;
case 1:
//这个时候subBuf 为sfds
break;
case 2:
//这个时候subBuf 为jieuri
break;
case 3:
//这个时候subBuf 为lj122
break;
case 4:
//这个时候subBuf 为98098
break;
}
}
wutaihua 2008-09-05
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 wutaihua 的回复:]


后台最压轴的回答

C/C++ code
szBuf。Format("sssdf sfds jieuri lj122 98098")
while(AfxExtractSubString(szBuf,subBuf.GetBuffer(0),nCount++," ")) //空格才是,不好意思
{
switch (nCount)
{
case 0:
//这个时候subBuf 为sssdf
break;
case 1:
//这个时候subBuf 为sfds
break;
case 2:
//这个时候subBuf 为jieuri
break;
case 3:
//这个时候subBuf 为lj122
break;
case 4:

[/Quote]
wutaihua 2008-09-05
  • 打赏
  • 举报
回复


后台最压轴的回答

szBuf。Format("sssdf sfds jieuri lj122 98098")
while(AfxExtractSubString(szBuf,subBuf.GetBuffer(0),nCount++,"\t"))
{
switch (nCount)
{
case 0:
//这个时候subBuf 为sssdf
break;
case 1:
//这个时候subBuf 为sfds
break;
case 2:
//这个时候subBuf 为jieuri
break;
case 3:
//这个时候subBuf 为lj122
break;
case 4:
//这个时候subBuf 为98098
break;
}
}

THCNC 2008-09-05
  • 打赏
  • 举报
回复
重整了一下7楼的代码
1 楼的应该是正解,如果你不想用2个循环,则更改一下函数的定义方式:
int splitString(CString str, char split, CStringArray& strArray)
{
  strArray.RemoveAll();

  CString strTemp = str; //此赋值不能少
  int nIndex = 0; //
  while( 1 )
  {
    nIndex = strTemp.Find( split );
    if( nIndex >= 0 )
    {
      strArray.Add( strTemp.Left( nIndex ) );
      strTemp = strTemp.Right( strTemp.GetLength() - nIndex - 1 );
    }
    else break;
  }
  strArray.Add( strTemp );
  return strArray.GetSize();
}

以下代码测试该函数
CStringArray str;
int nSize = splitString( "AAA BBB CCC", ' ', str );
for( int i = 0; i < nSize; i ++ )
{
  AfxMessageBox( str.GetAt( i ) );
}
zhb1190 2008-09-05
  • 打赏
  • 举报
回复
如果是UNICODE直接用这个好了CStringT::Tokenize
THCNC 2008-09-05
  • 打赏
  • 举报
回复
1 楼的应该是正解,如果你不想用2个循环,则更改一下函数的定义方式:
int splitString(CString str, char split, CStringArray& strArray)
{
strArray.RemoveAll();

CString strTemp = str; //此赋值不能少
int nIndex = 0; //
while( 1 )
{
nIndex = strTemp.Find( ' ' );
if( nIndex >= 0 )
{
strArray.Add( strTemp.Left( nIndex ) );
strTemp = strTemp.Right( strTemp.GetLength() - nIndex - 1 );
}
else break;
}
strArray.Add( strTemp );
return strArray.GetSize();
}

以下代码测试该函数
CStringArray str;
int nSize = splitString( "AAA BBB CCC", ' ', str );
for( int i = 0; i < szie; i ++ )
{
AfxMessageBox( str.GetAt( i ) );
}

sscanf函数不能实现LZ的要求的,sscanf函数是确定字符串中有多少数据段后,按照数据段的多少来分割,LZ要求的是不确定的字符串的分割,而且要求返回分割后的字符串数组

16,549

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧