`
jishublog
  • 浏览: 868847 次
文章分类
社区版块
存档分类
最新评论

MFC使用CFile读写Unicode字符集文件

 
阅读更多

我用MFC写了一个对话框。
在工程属性里使用Unicode字符集。然后加入一个编辑框空间。在文本编辑框内输入汉字。然后给空间关联了一个CString的变量,然后保存到TXT文件里是乱码。
但是如果在工程属性里使用多字节字符集的话。重复上述步骤,没有乱码出现。。。
求解。。。
为什么使用多字节字符集的话,对话框的按钮都变成Win98那种模式的了?而使用Unicode字符集则有立体感。。
这让我很难抉择啊。。。我是个画面党。。那种按钮确实太难看了。。。
有什么两全的办法吗??
望高人给出解答。。。
谢谢。。。
(注:使用两种字符集都能正常的打开一个TXT文件。。)
打开方式的代码是:

  1. CFileDialogfileDlg(TRUE);
  2. fileDlg.m_ofn.lpstrTitle=TEXT("打开文件");
  3. fileDlg.m_ofn.lpstrFilter=TEXT("文本文件(*.txt)\0*.txt\0\0");
  4. if(IDOK==fileDlg.DoModal())
  5. {
  6. CFilefile(fileDlg.GetPathName(),CFile::modeRead);
  7. char*ch=newchar[file.GetLength()+1];
  8. ch[file.GetLength()]=0;
  9. file.Read(ch,file.GetLength());
  10. file.Close();
  11. m_Text=ch;
  12. }
  13. UpdateData(FALSE);



m_Text是控件关联的CString变量,直接使用会出错。。。因为找不出什么原因,我new了一个char数组。然后吧char数组的内容给了m_Text。。。。

写入文件的代码是:

  1. UpdateData();
  2. CFileDialogfileDlg(FALSE);
  3. fileDlg.m_ofn.lpstrTitle=TEXT("保存文件");
  4. fileDlg.m_ofn.lpstrFilter=TEXT("文本文件(*.txt)\0*.txt\0\0");
  5. fileDlg.m_ofn.lpstrDefExt=TEXT("txt");
  6. if(IDOK==fileDlg.DoModal())
  7. {
  8. CFilefile(fileDlg.GetPathName(),CFile::modeCreate|CFile::modeWrite);
  9. file.Write(m_Text,m_Text.GetLength());
  10. file.Close();
  11. }


写入Unicode文本时,要在文件头部加入Unicode文本标志0XFEFF。

  1. #include<stdio.h>
  2. #ifndef_UNICODE
  3. #define_UNICODE//使用UNICODE编码
  4. #endif
  5. #include<Afx.h>//为了使用CString类
  6. constintUNICODE_TXT_FLG=0xFEFF;//UNICODE文本标示
  7. intmain()
  8. {
  9. FILE*WriteF;
  10. CStringWstr=_T("一个测试写入文本");
  11. WriteF=fopen("d:\\test.txt","w+");
  12. if(WriteF)
  13. {
  14. fwrite(&UNICODE_TXT_FLG,2,1,WriteF);//写入头部
  15. fwrite(Wstr.GetBuffer(10),Wstr.GetLength()*2,1,WriteF);
  16. fclose(WriteF);
  17. }
  18. return0;
  19. }


MFC代码如下:

  1. #include<stdio.h>
  2. #ifndef_UNICODE
  3. #define_UNICODE
  4. #endif
  5. #include<Afx.h>
  6. constintUNICODE_TXT_FLG=0xFEFF;
  7. //intmain()
  8. //{
  9. //FILE*WriteF;
  10. //
  11. //
  12. //CStringWstr=_T("一个测试写入文本");
  13. //WriteF=fopen("d:\\test.txt","w+");
  14. //
  15. //if(WriteF)
  16. //{
  17. //fwrite(&UNICODE_TXT_FLG,2,1,WriteF);
  18. //fwrite(Wstr.GetBuffer(10),Wstr.GetLength()*2,1,WriteF);
  19. //fclose(WriteF);
  20. //}
  21. //
  22. //return0;
  23. //}
  24. intmain()
  25. {
  26. CFileWriteF;
  27. CStringWstr=_T("一个测试写入文本");
  28. WriteF.Open(_T("d:\\test.txt"),CFile::modeCreate|CFile::modeWrite);
  29. if(WriteF)
  30. {
  31. WriteF.Write(&UNICODE_TXT_FLG,2);
  32. WriteF.Write(Wstr.GetBuffer(10),Wstr.GetLength()*2);
  33. WriteF.Flush();
  34. WriteF.Close();
  35. }
  36. return0;
  37. }


读的代码如下:

  1. m_Text.Empty();
  2. CFileReadF(fileDlg.GetPathName(),CFile::modeRead);
  3. TCHAR*temp=newTCHAR[ReadF.GetLength()/2+1];
  4. ReadF.Read(temp,ReadF.GetLength());
  5. temp[ReadF.GetLength()/2]=0;
  6. ReadF.Close();
  7. m_Text=temp;
  8. deletetemp;



这样的话能正常的写入和打开Unicode字符集的TXT文件了。。
可是那些非Unicode的文件就变成乱码了。。。
是不是应该加个判断语句???应该怎么加??



分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics