我在开放中经常会遇到编码的问题,今天我碰到的就是在英文操作系统下显示乱码的问题,让我头疼了大半天,我在这里整理出来这些代码,希望对你有用,哈哈!上一篇我转了一篇编码的基础知识有兴趣可以看看!
判断是否是GB2132:
int nWSize = MultiByteToWideChar(936,MB_ERR_INVALID_CHARS,strInfo,-1,NULL,0);
int error = GetLastError();
if (error == ERROR_NO_UNICODE_TRANSLATION)
{
TGLOGFILE(("no GB2312"), (""));
}
判断是否是UTF8,只要把936用CP_UTF8代替即可.
//转换任何字符集之间的代码,使用方法:
eg: UTF8转到GB2312 CString sResult = Convert(strUtf8, CP_UTF8, 936);
CString Convert(CString str, int sourceCodepage, int targetCodepage)
{
int len=str.GetLength();
int unicodeLen=MultiByteToWideChar(sourceCodepage,0,str,-1,NULL,0);
wchar_t* pUnicode;
pUnicode=new wchar_t[unicodeLen+1];
memset(pUnicode,0,(unicodeLen+1)*sizeof(wchar_t));
MultiByteToWideChar(sourceCodepage,0,str,-1,(LPWSTR)pUnicode,unicodeLen);
BYTE * pTargetData = NULL;
int targetLen=WideCharToMultiByte(targetCodepage,0,(LPWSTR)pUnicode,-1,(char *)pTargetData,0,NULL,NULL);
pTargetData=new BYTE[targetLen+1];
memset(pTargetData,0,targetLen+1);
WideCharToMultiByte(targetCodepage,0,(LPWSTR)pUnicode,-1,(char *)pTargetData,targetLen,NULL,NULL);
CString rt;
rt.Format("%s",pTargetData);
delete []pUnicode;
delete []pTargetData;
return rt;
}
该方法是固化的一个UTF8toGB2312的一个函数:
CString ConvertUTF8toGB2312(const char *pData, size_t size)
{
size_t n = MultiByteToWideChar(CP_UTF8, 0, pData, (int)size, NULL, 0);
WCHAR * pChar = new WCHAR[n+1];
n = MultiByteToWideChar(CP_UTF8, 0, pData, (int)size, pChar, n);
pChar[n]=0;
n = WideCharToMultiByte(936, 0, pChar, -1, 0, 0, 0, 0);
char *p = new char[n+1];
n = WideCharToMultiByte(936, 0, pChar, -1, p, (int)n, 0, 0);
CString result(p);
delete []pChar;
delete []p;
return result;
}
我们需要不断积累和总结,我会把碰到的头疼问题放到这里,希望我不会再问同样问题头疼!
作者:wangweixing2000
判断是否是GB2132:
int nWSize = MultiByteToWideChar(936,MB_ERR_INVALID_CHARS,strInfo,-1,NULL,0);
int error = GetLastError();
if (error == ERROR_NO_UNICODE_TRANSLATION)
{
TGLOGFILE(("no GB2312"), (""));
}
判断是否是UTF8,只要把936用CP_UTF8代替即可.
//转换任何字符集之间的代码,使用方法:
eg: UTF8转到GB2312 CString sResult = Convert(strUtf8, CP_UTF8, 936);
CString Convert(CString str, int sourceCodepage, int targetCodepage)
{
int len=str.GetLength();
int unicodeLen=MultiByteToWideChar(sourceCodepage,0,str,-1,NULL,0);
wchar_t* pUnicode;
pUnicode=new wchar_t[unicodeLen+1];
memset(pUnicode,0,(unicodeLen+1)*sizeof(wchar_t));
MultiByteToWideChar(sourceCodepage,0,str,-1,(LPWSTR)pUnicode,unicodeLen);
BYTE * pTargetData = NULL;
int targetLen=WideCharToMultiByte(targetCodepage,0,(LPWSTR)pUnicode,-1,(char *)pTargetData,0,NULL,NULL);
pTargetData=new BYTE[targetLen+1];
memset(pTargetData,0,targetLen+1);
WideCharToMultiByte(targetCodepage,0,(LPWSTR)pUnicode,-1,(char *)pTargetData,targetLen,NULL,NULL);
CString rt;
rt.Format("%s",pTargetData);
delete []pUnicode;
delete []pTargetData;
return rt;
}
该方法是固化的一个UTF8toGB2312的一个函数:
CString ConvertUTF8toGB2312(const char *pData, size_t size)
{
size_t n = MultiByteToWideChar(CP_UTF8, 0, pData, (int)size, NULL, 0);
WCHAR * pChar = new WCHAR[n+1];
n = MultiByteToWideChar(CP_UTF8, 0, pData, (int)size, pChar, n);
pChar[n]=0;
n = WideCharToMultiByte(936, 0, pChar, -1, 0, 0, 0, 0);
char *p = new char[n+1];
n = WideCharToMultiByte(936, 0, pChar, -1, p, (int)n, 0, 0);
CString result(p);
delete []pChar;
delete []p;
return result;
}
我们需要不断积累和总结,我会把碰到的头疼问题放到这里,希望我不会再问同样问题头疼!
作者:wangweixing2000