中文和unicode字符的相互转换
2014-03-19 23:23
393 查看
中文转换成unicode:
wchar_t* ChangeCODE(const wchar_t *lpText)
{
int nLen = wcslen(lpText)+1;
wchar_t *wcsTmp = new wchar_t[nLen];
memset(wcsTmp,0,nLen);
wcscpy_s(wcsTmp,nLen,lpText);
wchar_t *newTmp = new wchar_t[nLen*4];
memset(newTmp, 0, nLen*4);
for(int i=0; i<nLen-1; ++i)
{
wchar_t buf[5] = L"";
swprintf_s(buf,5, L"%04X", wcsTmp[i]);
wcscat(newTmp, buf);
}
delete []wcsTmp;
return newTmp;
}
unicode转换成中文
bool HexCharToDigital(__in const char* HexStr, __in const unsigned int nLen, __out unsigned int& Digtal)
{
if(nLen != 4)
return false;
Digtal = 0;
char ch;
for(int i=nLen-1; i>=0; --i)
{
switch(HexStr[i])
{
case 'a':
case 'A':
ch = 10;
break;
case 'b':
case 'B':
ch = 11;
break;
case 'c':
case 'C':
ch = 12;
break;
case 'd':
case 'D':
ch = 13;
break;
case 'e':
case 'E':
ch = 14;
break;
case 'f':
case 'F':
ch = 15;
break;
default:
if(!isdigit(HexStr[i]))
return false;
ch = HexStr[i] - 0x30;
break;
}
Digtal += (ch << ((3-i)*4));
}
return true;
}
bool HexCharUniCodeToWString(__in const char* HexCharUniCode, __in const unsigned int nLen, __out std::wstring& wStr)
{
if(HexCharUniCode == NULL || nLen == 0 || (nLen%4) != 0)
{
return false;
}
wStr.clear();
unsigned int dig;
for(unsigned int i=0; i<nLen; i+=4)
{
if(!HexCharToDigital(&HexCharUniCode[i], 4, dig))
{
return false;
}
wStr += dig;
}
return true;
}
eg:
std::wstring wtrystr1, wtrystr2;
char chTmp_a[] = "5173004F004B";
HexCharUniCodeToWString(chTmp_a, strlen(chTmp_a), wtrystr1);
wchar_t* ChangeCODE(const wchar_t *lpText)
{
int nLen = wcslen(lpText)+1;
wchar_t *wcsTmp = new wchar_t[nLen];
memset(wcsTmp,0,nLen);
wcscpy_s(wcsTmp,nLen,lpText);
wchar_t *newTmp = new wchar_t[nLen*4];
memset(newTmp, 0, nLen*4);
for(int i=0; i<nLen-1; ++i)
{
wchar_t buf[5] = L"";
swprintf_s(buf,5, L"%04X", wcsTmp[i]);
wcscat(newTmp, buf);
}
delete []wcsTmp;
return newTmp;
}
unicode转换成中文
bool HexCharToDigital(__in const char* HexStr, __in const unsigned int nLen, __out unsigned int& Digtal)
{
if(nLen != 4)
return false;
Digtal = 0;
char ch;
for(int i=nLen-1; i>=0; --i)
{
switch(HexStr[i])
{
case 'a':
case 'A':
ch = 10;
break;
case 'b':
case 'B':
ch = 11;
break;
case 'c':
case 'C':
ch = 12;
break;
case 'd':
case 'D':
ch = 13;
break;
case 'e':
case 'E':
ch = 14;
break;
case 'f':
case 'F':
ch = 15;
break;
default:
if(!isdigit(HexStr[i]))
return false;
ch = HexStr[i] - 0x30;
break;
}
Digtal += (ch << ((3-i)*4));
}
return true;
}
bool HexCharUniCodeToWString(__in const char* HexCharUniCode, __in const unsigned int nLen, __out std::wstring& wStr)
{
if(HexCharUniCode == NULL || nLen == 0 || (nLen%4) != 0)
{
return false;
}
wStr.clear();
unsigned int dig;
for(unsigned int i=0; i<nLen; i+=4)
{
if(!HexCharToDigital(&HexCharUniCode[i], 4, dig))
{
return false;
}
wStr += dig;
}
return true;
}
eg:
std::wstring wtrystr1, wtrystr2;
char chTmp_a[] = "5173004F004B";
HexCharUniCodeToWString(chTmp_a, strlen(chTmp_a), wtrystr1);
相关文章推荐
- 中文字符 与 十六进制Unicode编码 相互转换
- native2ascii 中文字符与Unicode编码相互转换
- UNICODE下宽字符的CString转换为const char *和char到WCHAR的相互转换
- 中文字符编码的相互转换(四)
- 用jdk自带的native2ascii转换中文字符为unicode
- UTF-8和GBK等中文字符编码格式介绍及相互转换
- unicode字符和多字节字符的相互转换接口
- 中文字符编码的相互转换(三)
- 编码转换(ASCII和Unicode、Unicode和中文相互转换)
- 关于JAVA字符编码:Unicode,ISO-8859-1,GBK,UTF-8编码及相互转换
- UNICODE 码和字符的相互转换
- WindowsPhone的中文GB2312、GBK编码与Unicode相互转换
- 中文字符ASCII码和NSString相互转换
- JAVA字符编码系列二:Unicode,ISO-8859,GBK,UTF-8编码及相互转换
- 使用 Java 将中文字符转换成 Unicode 编码
- unicode字符和String类型相互转换
- Java String字符串和Unicode字符相互转换代码(包括混有普通字符的Unicode)
- Java String字符串和Unicode字符相互转换代码
- Java将中文转换成unicode字符。
- js中 字符串与Unicode 字符值序列的相互转换