您的位置:首页 > 其它

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

2005-04-04 14:21 344 查看
自己写的一个函数。

如果字符串中含有中文,简单截取会出现乱码,简单的做法是,把它先转换成宽字符然后截取,完成后再转回来。当然,对于本身是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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐