繁体与简体的转换(C++实现)
2009-03-03 10:14
489 查看
以下提供繁体和简体的相互转换函数,本函数也是在网络上收集到经本人修改后适合C++语言使用的函数
//简体到繁体
int ConvertGb2312ToBig5(string& _DstText,const string& _SrcString)
{
char* pszGbt=NULL; //Gb编码的繁体字符
char* pszGbs=NULL; //Gb编码的简体字符
wchar_t* wszUnicode=NULL; //Unicode编码的字符
char* pszBig5=NULL; //Big5编码的字符
string sBig5; //返回的字符串
int iLen=0; //需要转换的字符数
pszGbs=(char*)((LPCSTR)_SrcString.c_str()); //读入需要转换的字符参数
//计算转换的字符数
iLen=MultiByteToWideChar (936, 0, pszGbs, -1, NULL,0) ;
//给pszGbt分配内存
pszGbt=new char[iLen*2+1];
//转换Gb码简体到Gb码繁体,使用API函数LCMapString
LCMapString(0x0804,LCMAP_TRADITIONAL_CHINESE, pszGbs, -1, pszGbt, iLen*2);
//给wszUnicode分配内存
wszUnicode=new wchar_t[iLen+1];
//转换Gb码到Unicode码,使用了API函数MultiByteToWideChar
MultiByteToWideChar (936, 0, pszGbt, -1, wszUnicode,iLen);
//计算转换的字符数
iLen=WideCharToMultiByte (950, 0, (PWSTR) wszUnicode, -1, NULL,0, NULL, NULL) ;
//给pszBig5分配内存
pszBig5=new char[iLen+1];
//转换Unicode码到Big5码,使用API函数WideCharToMultiByte
WideCharToMultiByte (950, 0, (PWSTR) wszUnicode, -1, pszBig5,iLen, NULL, NULL) ;
//返回Big5码字符
sBig5=pszBig5;
//释放内存
delete [] wszUnicode;
delete [] pszGbt;
delete [] pszBig5;
//返回
_DstText=sBig5;
return 1;
}
//繁体到简体
int ConvertBig5ToGb2312(string& _DstText,const string& _SrcString)
{
//1、转换Big5到Unicode
//2、转换Unicode到Gb繁体
//3、转换Gb繁体到Gb简体
char* pszBig5=NULL; //Big5编码的字符
wchar_t* wszUnicode=NULL; //Unicode编码的字符
char* pszGbt=NULL; //Gb编码的繁体字符
char* pszGbs=NULL; //Gb编码的简体字符
string sGb; //返回的字符串
int iLen=0; //需要转换的字符数
pszBig5=(char*)((LPCSTR)_SrcString.c_str()); //读入需要转换的字符参数
//计算转换的字符数
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);
//计算转换的字符数
iLen=WideCharToMultiByte (936, 0, (PWSTR) wszUnicode, -1, NULL,0, NULL, NULL) ; //给pszGbt分配内存
pszGbt=new char[iLen+1];
//给pszGbs分配内存
pszGbs=new char[iLen+1];
//转换Unicode码到Gb码繁体,使用API函数WideCharToMultiByte
WideCharToMultiByte (936, 0, (PWSTR) wszUnicode, -1, pszGbt,iLen, NULL, NULL) ; //转换Gb码繁体到Gb码简体,使用API函数LCMapString
LCMapString(0x0804,LCMAP_SIMPLIFIED_CHINESE, pszGbt, -1, pszGbs, iLen);
//返回Gb码简体字符
sGb=pszGbs;
//释放内存
delete [] wszUnicode;
delete [] pszGbt;
delete [] pszGbs;
//返回
_DstText=sGb;
return 1;
}
//简体到繁体
int ConvertGb2312ToBig5(string& _DstText,const string& _SrcString)
{
char* pszGbt=NULL; //Gb编码的繁体字符
char* pszGbs=NULL; //Gb编码的简体字符
wchar_t* wszUnicode=NULL; //Unicode编码的字符
char* pszBig5=NULL; //Big5编码的字符
string sBig5; //返回的字符串
int iLen=0; //需要转换的字符数
pszGbs=(char*)((LPCSTR)_SrcString.c_str()); //读入需要转换的字符参数
//计算转换的字符数
iLen=MultiByteToWideChar (936, 0, pszGbs, -1, NULL,0) ;
//给pszGbt分配内存
pszGbt=new char[iLen*2+1];
//转换Gb码简体到Gb码繁体,使用API函数LCMapString
LCMapString(0x0804,LCMAP_TRADITIONAL_CHINESE, pszGbs, -1, pszGbt, iLen*2);
//给wszUnicode分配内存
wszUnicode=new wchar_t[iLen+1];
//转换Gb码到Unicode码,使用了API函数MultiByteToWideChar
MultiByteToWideChar (936, 0, pszGbt, -1, wszUnicode,iLen);
//计算转换的字符数
iLen=WideCharToMultiByte (950, 0, (PWSTR) wszUnicode, -1, NULL,0, NULL, NULL) ;
//给pszBig5分配内存
pszBig5=new char[iLen+1];
//转换Unicode码到Big5码,使用API函数WideCharToMultiByte
WideCharToMultiByte (950, 0, (PWSTR) wszUnicode, -1, pszBig5,iLen, NULL, NULL) ;
//返回Big5码字符
sBig5=pszBig5;
//释放内存
delete [] wszUnicode;
delete [] pszGbt;
delete [] pszBig5;
//返回
_DstText=sBig5;
return 1;
}
//繁体到简体
int ConvertBig5ToGb2312(string& _DstText,const string& _SrcString)
{
//1、转换Big5到Unicode
//2、转换Unicode到Gb繁体
//3、转换Gb繁体到Gb简体
char* pszBig5=NULL; //Big5编码的字符
wchar_t* wszUnicode=NULL; //Unicode编码的字符
char* pszGbt=NULL; //Gb编码的繁体字符
char* pszGbs=NULL; //Gb编码的简体字符
string sGb; //返回的字符串
int iLen=0; //需要转换的字符数
pszBig5=(char*)((LPCSTR)_SrcString.c_str()); //读入需要转换的字符参数
//计算转换的字符数
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);
//计算转换的字符数
iLen=WideCharToMultiByte (936, 0, (PWSTR) wszUnicode, -1, NULL,0, NULL, NULL) ; //给pszGbt分配内存
pszGbt=new char[iLen+1];
//给pszGbs分配内存
pszGbs=new char[iLen+1];
//转换Unicode码到Gb码繁体,使用API函数WideCharToMultiByte
WideCharToMultiByte (936, 0, (PWSTR) wszUnicode, -1, pszGbt,iLen, NULL, NULL) ; //转换Gb码繁体到Gb码简体,使用API函数LCMapString
LCMapString(0x0804,LCMAP_SIMPLIFIED_CHINESE, pszGbt, -1, pszGbs, iLen);
//返回Gb码简体字符
sGb=pszGbs;
//释放内存
delete [] wszUnicode;
delete [] pszGbt;
delete [] pszGbs;
//返回
_DstText=sGb;
return 1;
}
相关文章推荐
- python实现中文字符繁体和简体中文转换
- Android中文简体繁体互相转换的实现(繁简互转)
- C#实现简体中文和繁体中文的转换
- C#实现简体中文和繁体中文的转换
- PHP 实现中文简体转换繁体程序
- 字体转换接口实现简体、繁体、火星文之间的转换
- 利用客户端js实现汉字简体繁体转换
- 基于JavaScript实现快速转换文本语言(繁体中文和简体中文)
- C#实现简体繁体之间转换
- javascript实现简体与繁体的转换
- VB6用API实现繁体简体转换
- javascript实现繁体简体转换
- 实现一个网站简体中文和繁体中文的转换
- python实现中文字符繁体和简体中文转换
- 基于JavaScript实现快速转换文本语言(繁体中文和简体中文)
- js 实现繁体和简体之间的转换
- 使用SAS实现对表中字段的简体和繁体的转换
- javascript实现简体与繁体的转换(可下载)
- Asp.net 如何实现简体到繁体的转换
- 在英文版的Office 2007中实现 中文 繁体和简体的相互转换