使用CFile操作文件十分方便,但是却会遇到输出汉字到文件后变成乱码的困扰
在网上搜索解决方案得到的结果大多如下:
1.选择多字节模式编译程序 2.使用WideCharToMultiByte函数将宽字符转换为窄字符再输出
例如下面的代码在多字节编译模式下能输出汉字到文件
[cpp] view plain copy print ?
- CFile fileout;
- fileout.Open(_T("report.txt"),CFile::shareExclusive|CFile::modeWrite|CFile::modeCreate);
-
- CString strTitle= _T("汉字汉字/r/n");
-
- fileout.Write(strTitle.GetBuffer(), strTitle.GetLength());
CFile fileout; fileout.Open(_T("report.txt"),CFile::shareExclusive|CFile::modeWrite|CFile::modeCreate); CString strTitle= _T("汉字汉字/r/n"); fileout.Write(strTitle.GetBuffer(), strTitle.GetLength());
但是很多情况下我们都希望使用UNICODE模式编译,同时我们也会有疑问,难道就不能把unicode的字符正常输出到文件里面吗?
网上流行的答案显然没有命中问题的要害!其实,unicode字符已经被Cfile忠实地输入了文件当中!遗憾的是字处理软件(如:记事本)不知道其中是unicode字符,将他们统统当做了单字节字符处理。
要想让字处理软件识别unicode必须在文件头上加入unicode编码的前导字符:0xff, 0xfe。
于是,可以用下面的代码实现汉字的输出且用字处理软件打开不会乱码
[c-sharp] view plain copy print ?
- #difine TCHARLEN (sizeof(TCHAR)) // 一个字符占的字节数
-
- CFile fileout;
- fileout.Open(_T("report.txt"),CFile::shareExclusive|CFile::modeWrite|CFile::modeCreate);
-
- ULONGLONG dwFileLen = fileout.GetLength();
- if (0 == dwFileLen)
- {
- const unsigned char LeadBytes[] = {0xff, 0xfe};
- fileout.Write(LeadBytes, sizeof(LeadBytes));
- }
-
- CString strTitle;
- strTitle = _T("汉字汉字/r/n");
-
- fileout.Write(strTitle.GetBuffer(), strTitle.GetLength()*TCHARLEN);
#difine TCHARLEN (sizeof(TCHAR)) // 一个字符占的字节数 CFile fileout; fileout.Open(_T("report.txt"),CFile::shareExclusive|CFile::modeWrite|CFile::modeCreate); ULONGLONG dwFileLen = fileout.GetLength(); if (0 == dwFileLen) // 文件为空时写入UNICODE字节序标记 { const unsigned char LeadBytes[] = {0xff, 0xfe}; fileout.Write(LeadBytes, sizeof(LeadBytes)); } CString strTitle; strTitle = _T("汉字汉字/r/n"); fileout.Write(strTitle.GetBuffer(), strTitle.GetLength()*TCHARLEN);// 注意:输出的字节数与字符数并不一致
打完,收工.......