6 个解决方案
#1
我只有从UTF-8转换为Big5编码的,你要吗
#2
你可以去看libconv,这个代码是开源的。当然你直接用他的库也可以。
#3
不太明白你的意思. 在xml中都用utf-8不是行了?
<?xml version="1.0" encoding="utf-8" ?>
<?xml version="1.0" encoding="utf-8" ?>
#4
仅仅设置encoding="utf-8",这是没用的,我需要的是文件编码转换。我要将big5的文件转换为UTF-8的
#5
以下是代码,可以参考一下:
int CUnicodeFunction::Big2GbAnsi( unsigned char *sBig ,int len ,CString& sGbOut )
{
char* pszBig5=NULL; //Big5编码的字符
wchar_t* wszUnicode=NULL; //Unicode编码的字符
char* pszGbt=NULL; //Gb编码的繁体字符
char* pszGbs=NULL; //Gb编码的简体字符
//CString sGb; //返回的字符串
int iLen=0; //需要转换的字符数
pszBig5 = new char[len];
memcpy( pszBig5, sBig, len );
//计算转换的字符数
iLen=MultiByteToWideChar (950, 0, pszBig5, -1, NULL,0) ;
//给wszUnicode分配内存
wszUnicode=new wchar_t[iLen+1];
//转换Big5码到Unicode码,使用了API函数MultiByteToWideChar
MultiByteToWideChar (950, 0, pszBig5, -1, wszUnicode,iLen);
}
int CUnicodeFunction::Big2GbAnsi( unsigned char *sBig ,int len ,CString& sGbOut )
{
char* pszBig5=NULL; //Big5编码的字符
wchar_t* wszUnicode=NULL; //Unicode编码的字符
char* pszGbt=NULL; //Gb编码的繁体字符
char* pszGbs=NULL; //Gb编码的简体字符
//CString sGb; //返回的字符串
int iLen=0; //需要转换的字符数
pszBig5 = new char[len];
memcpy( pszBig5, sBig, len );
//计算转换的字符数
iLen=MultiByteToWideChar (950, 0, pszBig5, -1, NULL,0) ;
//给wszUnicode分配内存
wszUnicode=new wchar_t[iLen+1];
//转换Big5码到Unicode码,使用了API函数MultiByteToWideChar
MultiByteToWideChar (950, 0, pszBig5, -1, wszUnicode,iLen);
}
#6
到 Unicode 中转一下 ...
#1
我只有从UTF-8转换为Big5编码的,你要吗
#2
你可以去看libconv,这个代码是开源的。当然你直接用他的库也可以。
#3
不太明白你的意思. 在xml中都用utf-8不是行了?
<?xml version="1.0" encoding="utf-8" ?>
<?xml version="1.0" encoding="utf-8" ?>
#4
仅仅设置encoding="utf-8",这是没用的,我需要的是文件编码转换。我要将big5的文件转换为UTF-8的
#5
以下是代码,可以参考一下:
int CUnicodeFunction::Big2GbAnsi( unsigned char *sBig ,int len ,CString& sGbOut )
{
char* pszBig5=NULL; //Big5编码的字符
wchar_t* wszUnicode=NULL; //Unicode编码的字符
char* pszGbt=NULL; //Gb编码的繁体字符
char* pszGbs=NULL; //Gb编码的简体字符
//CString sGb; //返回的字符串
int iLen=0; //需要转换的字符数
pszBig5 = new char[len];
memcpy( pszBig5, sBig, len );
//计算转换的字符数
iLen=MultiByteToWideChar (950, 0, pszBig5, -1, NULL,0) ;
//给wszUnicode分配内存
wszUnicode=new wchar_t[iLen+1];
//转换Big5码到Unicode码,使用了API函数MultiByteToWideChar
MultiByteToWideChar (950, 0, pszBig5, -1, wszUnicode,iLen);
}
int CUnicodeFunction::Big2GbAnsi( unsigned char *sBig ,int len ,CString& sGbOut )
{
char* pszBig5=NULL; //Big5编码的字符
wchar_t* wszUnicode=NULL; //Unicode编码的字符
char* pszGbt=NULL; //Gb编码的繁体字符
char* pszGbs=NULL; //Gb编码的简体字符
//CString sGb; //返回的字符串
int iLen=0; //需要转换的字符数
pszBig5 = new char[len];
memcpy( pszBig5, sBig, len );
//计算转换的字符数
iLen=MultiByteToWideChar (950, 0, pszBig5, -1, NULL,0) ;
//给wszUnicode分配内存
wszUnicode=new wchar_t[iLen+1];
//转换Big5码到Unicode码,使用了API函数MultiByteToWideChar
MultiByteToWideChar (950, 0, pszBig5, -1, wszUnicode,iLen);
}
#6
到 Unicode 中转一下 ...