Unicode文件解析方法及存在问题

问题背景

在项目中遇到需要将一个Unicode编码(UTF-16 LE)的文件内容解析出来,但是在使用MFC的类CStdioFile进行文件读取的时候,出现乱码。
在这里插入图片描述
同时,读取的文件有可能还是ASCII编码的,使用CStdioFile读取是可以正常读取。需要同时兼容两个编码。

问题分析

1、Unicode编码的文件其文件前两个字节是0xEF FF,可以以此来判定文件编码格式。
2、将文件以字节流的方式读取出来后,使用MultiBytesToWideChar可以转换成可见字符串。

解决方案

1、既然CStdioFile可以处理ASCII编码,那么可以派生一个类CMyStdioFile专门用于处理Unicode编码。即:CStdioFile处理ASCII编码,CMyStdioFile处理Unicode编码。
2、在打开文件的时候顺便将文件编码判定出来,保存在类成员中,后面使用

代码

#pragma once
#include "afx.h"
#include <string>

//用来处理Unicode格式的FORM文件读取
class CMyStdioFile :
	public CStdioFile
{
   
public:
	CMyStdioFile();
	virtual ~CMyStdioFile();
public:
	//打开文件,内部会判断文件是Unicode还是ASCII
	virtual BOOL Open(LPCTSTR lpszFileName, UINT nOpenFlags, CFileException* pError = NULL);

	//读取下一行的数据,可以支持Unicode文件和ASCII文件
	virtual BOOL ReadString(CString& rString);
private:
	<
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值