ANSI编码的文件读取后转UNICODE编码的字符串中文乱码,该如何解决
ANSI编码的文件读取后转UNICODE编码的字符串中文乱码
ANSI编码的文件读取后转UNICODE编码的字符串中文乱码
一个ANSI编码的文件,都取内容后用MultiByteToWideChar转UNICODE编码的字符串,结果中文乱码,VC2013
------解决思路----------------------
wstring 这个是啥东西?
------解决思路----------------------
第二个MultiByteToWideChar之后插入下面试试
if( pUnicode[0] == 0xFEFF) // skip Oxfeff
for(int i = 0; i < iUnicodeLen; i ++)
pUnicode[i] = pUnicode[i+1];
------解决思路----------------------
需要设定转换长度时可指定len值
------解决思路----------------------
中文你要考虑它用的是UTF8还是GB2312编码等。才能再对应codepage转换
ANSI编码的文件读取后转UNICODE编码的字符串中文乱码
一个ANSI编码的文件,都取内容后用MultiByteToWideChar转UNICODE编码的字符串,结果中文乱码,VC2013
wstring CtStringConvert::MBCS_Unicode(char* s, const int& is)
{
int iUnicodeLen = ::MultiByteToWideChar(CP_ACP,
0,
s,
is,
NULL,
0);
wchar_t * pUnicode = new wchar_t[iUnicodeLen + 1];
::memset(pUnicode, 0, (iUnicodeLen + 1) * sizeof(wchar_t));
::MultiByteToWideChar(CP_ACP,
0,
s,
is,
pUnicode,
iUnicodeLen);
wstring w;
w = (wchar_t*)pUnicode;
delete pUnicode;
return w;
}
------解决思路----------------------
wstring 这个是啥东西?
------解决思路----------------------
第二个MultiByteToWideChar之后插入下面试试
if( pUnicode[0] == 0xFEFF) // skip Oxfeff
for(int i = 0; i < iUnicodeLen; i ++)
pUnicode[i] = pUnicode[i+1];
------解决思路----------------------
需要设定转换长度时可指定len值
// ANSI To UNCODE转换
CString AnsiToUnicode(char * szAnsi, int len=0);
// ANSI To UNCODE转换
CString CStringProc::AnsiToUnicode(char * szAnsi, int len)
{
CString str;
// ansi to unicode
//预转换,得到所需空间的大小
int wcsLen;
if(len>0)
wcsLen=len;
else
wcsLen= ::MultiByteToWideChar(CP_ACP, NULL, szAnsi, strlen(szAnsi), NULL, 0);
//分配空间要给'\0'留个空间,MultiByteToWideChar不会给'\0'空间
wchar_t* wszString = new wchar_t[wcsLen + 1];
//转换
::MultiByteToWideChar(CP_ACP, NULL, szAnsi, strlen(szAnsi), wszString, wcsLen);
//最后加上'\0'
wszString[wcsLen] = '\0'; // UNICODE字串
str=wszString;
delete wszString;
return str;
}
------解决思路----------------------
中文你要考虑它用的是UTF8还是GB2312编码等。才能再对应codepage转换