
次のコードのように、CString ←→ BSTRの変換を行いたいのですが、データがUTF8だと文字化けしてしまいます。
どうすれば良いでしょうか?
環境:VC++7(.net 2003)+MFC+WinXP
【結果】
CString--------------------------
FFFFFFE2 FFFFFF97 FFFFFF8B 3C
BSTR--------------------------
FFFFFFE2 FFFFFF97 FFFFFF81 45
【ソース】
int intCT;
int nSize = 0;
BYTE *pSource = (BYTE *)"○<";
this->ConvSJistoUtf8(pSource, (BYTE *)NULL, &nSize );
BYTE* pDist = new BYTE[ nSize + 1 ];
ZeroMemory( pDist, nSize + 1 );
this->ConvSJistoUtf8(pSource, pDist, &nSize );
CString str = CString(pDist);
delete []pDist;
pDist = NULL;
BSTR bstr;
bstr=str.AllocSysString();//CString→BSTRへの変換
CString str2=CString(bstr);//BSTR→CStringへの変換
TRACE("CString--------------------------\n ");
for( intCT = 0; intCT < str.GetLength(); intCT++ )
{
if( intCT%16 == 0 ) TRACE("\n");
TRACE("%02X " , str[intCT]);
}
TRACE("\n ");
TRACE("BSTR--------------------------\n ");
for( intCT = 0; intCT < str2.GetLength(); intCT++ )
{
if( intCT%16 == 0 ) TRACE("\n");
TRACE("%02X " , str2[intCT]);
}
TRACE("\n ");
BOOL ConvSJistoUtf8( BYTE* pSource, BYTE* pDist, int* pSize )
{
*pSize = 0;
//ShiftJISからUTF-16へ変換
const int nSize = ::MultiByteToWideChar( CP_ACP, 0, (LPCSTR)pSource, -1, NULL, 0 );
BYTE* buffUtf16 = new BYTE[ nSize * 2 + 2 ];
::MultiByteToWideChar( CP_ACP, 0, (LPCSTR)pSource, -1, (LPWSTR)
buffUtf16, nSize );
//UTF-16からShift-JISへ変換
const int nSizeUtf8 = ::WideCharToMultiByte( CP_UTF8, 0, (LPCWSTR)
buffUtf16, -1, NULL, 0, NULL, NULL );
if( !pDist ){
*pSize = nSizeUtf8;
delete buffUtf16;
return TRUE;
}
BYTE* buffUtf8 = new BYTE[ nSizeUtf8 * 2 ];
ZeroMemory( buffUtf8, nSizeUtf8 * 2 );
::WideCharToMultiByte( CP_UTF8, 0, (LPCWSTR)buffUtf16, -1, (LPSTR)
buffUtf8, nSizeUtf8, NULL, NULL );
*pSize = lstrlen( (char*)buffUtf8 );
memcpy( pDist, buffUtf8, *pSize );
delete buffUtf16;
delete buffUtf8;
return TRUE;
}
No.1ベストアンサー
- 回答日時:
CString ←→ BSTRの変換以前に
>CString str = CString(pDist);
の時点で文字化けしてるんじゃないでしょうか?
int nSize = 0;
BYTE *pSource = (BYTE *)"○<";
// ASCII → CString
TRACE( "ASCII → CString\n " );
CString strA = CString( pSource );
TRACE( "%s\n ", strA );
for( int count = 0; count < strA.GetLength(); count++ ) {
TRACE( "%02X ", strA[ count ] );
}
TRACE( "\n\n" );
ConvSJistoUtf8( pSource, ( BYTE * )NULL, &nSize );
BYTE* pDist = new BYTE[ nSize + 1 ];
ZeroMemory( pDist, nSize + 1 );
ConvSJistoUtf8( pSource, pDist, &nSize );
// UTF8 → CString
TRACE("UTF8 → CString\n ");
CString str = CString( pDist );
TRACE( "%s\n ", str );
delete []pDist;
pDist = NULL;
for( int count = 0; count < str.GetLength(); count++ ) {
TRACE( "%02X ", str[ count ] );
}
Shift-JIS か UTF-16 で初期化しないとダメなのでは?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
EBCDIC⇒SJIS変換の方法
-
文字の変換 select case
-
std::stringからLPCWSTR型への変換
-
ふりがなをアルファベット化す...
-
VS 2008(VB.NET)
-
文字の変換 (アルファベット)
-
DOUBLE型の16進HEX文字列変換に...
-
- が&#8211;に変換されてしま...
-
入力した文字を全て自動で全角...
-
COBOLのデータ型
-
Excel vba で1と10を正確に判断...
-
sedで日本語の置換方法について
-
EBCDICへの変換
-
半角全角混在(JIS)をJEF+EBCDI...
-
ベタ打ちってなんですか?
-
Excelで入力禁止文字を設定したい
-
DOHCとOHC
-
濁点(゙) 半濁点(゚)を一文字と数...
-
PS4コントローラーをPCでゲーム...
-
エクセルでアルファベットか数...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
EBCDIC⇒SJIS変換の方法
-
std::stringからLPCWSTR型への変換
-
セル内の文字列が日本語か英語...
-
「彡」って文字はなんという文...
-
VS 2008(VB.NET)
-
COBOLによる全角・半角混...
-
ふりがなをアルファベット化す...
-
Symfowareでのデータ型変換につ...
-
RubyでUTF8のコード値を文字に...
-
フォームのコントロールのバッ...
-
%fと%gについて
-
ExcelVBA実行後に時々落ちる
-
JIS → S-JIS コード変換するには
-
英数字を含む文字列(0-9,A-Z)...
-
sedで日本語の置換方法について
-
byte配列の内容をstringにコピ...
-
数字5桁文字コード?
-
accessでJISコードを求める関数
-
コード変換について
-
「髙(はしごたか)」を文字コー...
おすすめ情報