PB 9.0 处理pb importstringg字符转成utf-8格式,怎么弄

* 请教: 如何把 input里面的字符串转成 UTF-8 ?
[问题点数:50分,结帖人konfyt]
* 请教: 如何把 input里面的字符串转成 UTF-8 ?
[问题点数:50分,结帖人konfyt]
不显示删除回复
显示所有回复
显示星级回复
显示得分回复
只显示楼主
本帖子已过去太久远了,不再提供回复功能。5512人阅读
9. 边城编程(55)
(1) int& main(void)& {& &char& str& [& 256& ]& =& "唐志国"& ;&&& //一段UTF-8编码& &WCHAR*& strA;& &int& i=& MultiByteToWideChar& ( CP_ACP&& ,& 0& ,(char*)& str& ,-1& ,NULL,0);& &strA& =& new& WCHAR[i];& &MultiByteToWideChar& (& CP_ACP& ,& 0& ,(& char& *& )& str,& -1,& strA& ,& i);& &&i=& WideCharToMultiByte(CP_UTF8,0,strA,-1,NULL,0,NULL,NULL);& &char& *strB=new& char[i];& &WideCharToMultiByte& (CP_UTF8,0,strA,-1,strB,i,NULL,NULL);& &//strB即为所求& &delete& []strA;& &delete& []strB;& &return& 0;& }&
(2) int& main(void)& {& &char& str& [& 256& ]& =& "唐志国"& ;&&& &WCHAR*& strA;& &int& i=& MultiByteToWideChar& ( CP_ACP&& ,& 0& ,(char*)& str& ,-1& ,NULL,0);& &strA& =& new& WCHAR[i];& &MultiByteToWideChar& (& CP_ACP& ,& 0& ,(& char& *& )& str,& -1,& strA& ,& i);& &&i=& WideCharToMultiByte(CP_UTF8,0,strA,-1,NULL,0,NULL,NULL);& &char& *strB=new& char[i];& &WideCharToMultiByte& (CP_UTF8,0,strA,-1,strB,i,NULL,NULL);& &//strB即为所求& &delete& []strA;& &delete& []strB;& &return& 0;& }&
(3) int& main(void)& {& &char& str& [& 256& ]& =& "唐志国"& ;&&& &WCHAR*& strA;& &int& i=& MultiByteToWideChar& ( CP_ACP&& ,& 0& ,(char*)& str& ,-1& ,NULL,0);& &strA& =& new& WCHAR[i];& &MultiByteToWideChar& (& CP_ACP& ,& 0& ,(& char& *& )& str,& -1,& strA& ,& i);& &&i=& WideCharToMultiByte(CP_UTF8,0,strA,-1,NULL,0,NULL,NULL);& &char& *strB=new& char[i];& &WideCharToMultiByte& (CP_UTF8,0,strA,-1,strB,i,NULL,NULL);& &//strB即为所求& &delete& []strA;& &delete& []strB;& &return& 0;& }&
(4) 这里面包含了两个方向的转换,你看一下吧#include&&& "Windows.h"& int& main(void)& {& &char& str& [& 256& ]& =& "唐志国"& ;&&& //一段UTF-8编码& &WCHAR*& strA;& &int& i=& MultiByteToWideChar& ( CP_ACP&& ,& 0& ,(char*)& str& ,-1& ,NULL,0);& &strA& =& new& WCHAR[i];& &MultiByteToWideChar& (& CP_ACP& ,& 0& ,(& char& *& )& str,& -1,& strA& ,& i);& &&i=& WideCharToMultiByte(CP_UTF8,0,strA,-1,NULL,0,NULL,NULL);& &char& *strB=new& char[i];& &WideCharToMultiByte& (CP_UTF8,0,strA,-1,strB,i,NULL,NULL);& &//strB即为所求&
&delete& []strA;& &&i=& MultiByteToWideChar& ( CP_UTF8&& ,& 0& ,(char*)& strB& ,-1& ,NULL,0);& &strA& =& new& WCHAR[i];& &MultiByteToWideChar& (& CP_UTF8& ,& 0& ,(& char& *& )& strB,& -1,& strA& ,& i);&
&delete& []strB;& &&i=& WideCharToMultiByte(CP_ACP,0,strA,-1,NULL,0,NULL,NULL);& &strB=new& char[i];& &WideCharToMultiByte& (CP_ACP,0,strA,-1,strB,i,NULL,NULL);& &//strB即为所求& &delete& []strA;& &&delete& []strB;&
&return& 0;& }&
(5) 这是转换函数:&int&CodePageConvert(UINT SrcCodePage, LPCTSTR pBuff, int iBuffLen, UINT DestCodePage, char* &lpCodePage)&{&&int iWideCharCnt = ::MultiByteToWideChar(SrcCodePage, 0, pBuff, iBuffLen, NULL, 0);&&LPWSTR lpszWideChar = new wchar_t[iWideCharCnt + 1];&&memset(lpszWideChar, 0, (iWideCharCnt + 1) * sizeof(WCHAR));&&iWideCharCnt = MultiByteToWideChar(SrcCodePage, 0, pBuff, iBuffLen, lpszWideChar, iWideCharCnt); &&if(DestCodePage == 54936 &&&&&& !IsValidCodePage(54936))&&&DestCodePage = 936; &&int iDestCnt = WideCharToMultiByte(DestCodePage, 0, lpszWideChar, iWideCharCnt, NULL, 0, NULL, NULL);&&lpCodePage = new char[iDestCnt + 1];&&memset(lpCodePage, 0, iDestCnt + 1);&&iDestCnt = WideCharToMultiByte(DestCodePage, 0, lpszWideChar, iWideCharCnt, lpCodePage, iDestCnt, NULL, NULL); &&delete []lpszWideC&&&return iDestC&}下面是调用方法:&& utf-8 到 gbk&int nLen = CodePageConvertUnix("UTF-8",_T("标准"),2,"GBK",lpOut);&& gbk 到utf-8int nLen = CodePageConvertUnix("UTF-8",_T("标准"),2,"GBK",lpOut);
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:194775次
积分:2193
积分:2193
排名:第11308名
转载:111篇
评论:19条
(41)(33)(37)传进原始gbk字符串,返回出去的是转成UTF8之后的字符串
好吧,看来问的人和回答的人都不一定清楚什么是“编码和编码格式”,以及如何理解“java中字符串的编码”;首先明确几点:unicode是一种“编码”,所谓编码就是一个编号(数字)到字符的一种映射关系,就仅仅是一种一对一的映射而已,可以理解成一个很大的对应表格GBK、UTF-8是一种“编码格式”,是用来序列化或存储1中提到的那个“编号(数字)”的一种“格式”;GBK和UTF-8都是用来序列化或存储unicode编码的数据的,但是分别是2种不同的格式; 他们俩除了格式不一样之外,他们所关心的unicode编码范围也不一样,utf-8考虑了很多种不同国家的字符,涵盖整个unicode码表,所以其存储一个字符的编码的时候,使用的字节长度也从1字节到4字节不等;而GBK只考虑中文——在unicode中的一小部分——的字符,的编码,所以它算好了只要2个字节就能涵盖到绝大多数常用中文(2个字节能表示6w多种字符),所以它存储一个字符的时候,所用的字节长度是固定的;上述2个概念不懂的请马上google,下面不再赘述;我下面说说这个问题本身...的问题在哪里首先java的string使用的编码是unicode,但是,当string存在于内存中时(也就是当程序运行时、你在代码中用string类型的引用对它进行操作时、也就是string没有被存在文件中且也没有在网络中传输(序列化)时),是“只有编码而没有编码格式的”,所以java程序中的任何String对象,说它是gbk还是utf-8都是错的,gbk和utf-8是编码格式而不是编码,String在内存中不需要“编码格式”(记住编码格式是在存文件或序列化的时候使用的), 它只是一个unicode的字符串而已所以java里面String是不带编码格式的,而String.toByteArray(charsetName)得到的byteArray是带编码格式的,格式就是你传入的'charsetName',我们不妨把toByteArray的这个过程叫做“编码”;另外,new String(byte[], charsetName)是把一个byte数组(带编码格式)以charsetName指定的编码格式翻译为一个不带编码格式的String对象,我们不妨把这个过程叫“解码”那么根据我揣测提问者的意图,可能有2种问法是他真正想问的:第一,如何把一个被错误地当作是gbk格式存储的utf-8格式的文件里面读出来的一段乱码字符串还原回去(也就是说本来二进制数据是utf-8的,你用gbk来解码它,得到的字符串是乱码,现在想要还原回去)第二种,如何把一个gbk文件转化为utf-8文件如果是第一种意图那就:public static void main(String... args) throws Throwable {
String errStr = "errStr";
System.out.println(recover(errStr));
public static String recover(String str) throws Throwable {
return new String(str.getBytes("GBK"), "UTF-8");
}其中errStr就是乱码字符串,按照相反的顺序在编码(用gbk)、解码(用utf-8)回去,就能得到正确的字符串(其实不保证所有情况均能正确还原,只能说大部分都能,要看你在乱码过程中是否有数据被丢失)如果是第二种意图,那就用InputStream以gbk格式将文件读到内存里(表示为String),再将这个String以UTF-8编码写入目标文件里,具体请参考InputStream/OutputStream的api
String s = &浣犲ソ&; //这是&你好&的gbk编码的字符串&br&
String ss = new String(s.getBytes(), &UTF-8&);&br&
System.out.println(ss);
String s = "浣犲ソ"; //这是"你好"的gbk编码的字符串
String ss = new String(s.getBytes(), "UTF-8");
System.out.println(ss);
String UTF-8= &UTF-8&;&br&String changeCharset(String oldStr,String charset){&br&
return new String( oldStr.getBytes(),charset);&br&}&br&还是多查查api吧。
String UTF-8= "UTF-8";String changeCharset(String oldStr,String charset){ return new String( oldStr.getBytes(),charset);}还是多查查api吧。
已有帐号?
无法登录?
社交帐号登录
I am pf_miles@Alibaba.求助,pb的字符串(不是文件)GB2312转utf-8代码。。
[问题点数:20分,结帖人toujyo]
求助,pb的字符串(不是文件)GB2312转utf-8代码。。
[问题点数:20分,结帖人toujyo]
不显示删除回复
显示所有回复
显示星级回复
显示得分回复
只显示楼主
2010年7月 总版技术专家分月排行榜第二2010年6月 总版技术专家分月排行榜第二
2010年5月 总版技术专家分月排行榜第三
本帖子已过去太久远了,不再提供回复功能。}

我要回帖

更多关于 pb blob转string 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信