截取包含多字节字符的字符串

类别:编程语言 点击:0 评论:0 推荐:

自己写的一个函数。

如果字符串中含有中文,简单截取会出现乱码,简单的做法是,把它先转换成宽字符然后截取,完成后再转回来。当然,对于本身是Unicode的程序,直接截取就行了,不必转换。

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

BOOL TruncStringLeft(LPTSTR lpszSource, int nCnt)
{
 ATLASSERT(lpszSource);
 if(NULL == lpszSource || nCnt <1 || !lpszSource[0])
  return FALSE;

 WCHAR wszWide[MAX_PATH * 2];
#ifdef UNICODE
 _tcscpy(wszWide, lpszSource);
#else
 MultiByteToWideChar(CP_ACP, 0, lpszSource, -1, wszWide, ARRAYSIZE(wszWide));
#endif
 
 if(wcslen(wszWide)>nCnt)
  wszWide[nCnt] = 0;

#ifdef UNICODE
 _tcscpy(lpszSource, wszWide);
#else
 WideCharToMultiByte(CP_ACP, 0, wszWide, -1, lpszSource, MAX_PATH, NULL, NULL);
#endif

 return TRUE;
}


///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

一些相关的讨论:
http://dev.csdn.net/develop/article/66/66387.shtm
http://community.csdn.net/Expert/topic/3906/3906053.xml?temp=.4827692

本文地址:http://com.8s8s.com/it/it22588.htm