c#的IO流怎么读GB2312编码或其他编码的文本文件?
c#的IO流怎么读GB2312编码或其他编码的文本文件?如果是鼠标右键新建的文本文件,用IO的UTF8编码读不出中文,只能读UTF8编码的文本文件,但用GB2312编码器...
c#的IO流怎么读GB2312编码或其他编码的文本文件?
如果是鼠标右键新建的文本文件,用IO的UTF8编码读不出中文,只能读UTF8编码的文本文件,但用GB2312编码器可以读出,反之,用GB2312的编码器可以读UTF8和GB2312的文本文件?这是为什么啊? 展开
如果是鼠标右键新建的文本文件,用IO的UTF8编码读不出中文,只能读UTF8编码的文本文件,但用GB2312编码器可以读出,反之,用GB2312的编码器可以读UTF8和GB2312的文本文件?这是为什么啊? 展开
1个回答
2013-08-21
展开全部
首先给你解释原因
记事本的默认编码格式是ANSI,所以你用UTF8读取记事本文件的中文会乱码,
解决方法有两种:
一是用StreamRead去读,new的时候传出两个参数,第一个是路径
第二个是编码格式,你可以指定为枚举类型中的默认编码格式
StreamReader sr= new StreamReader(filename,Encoding.Default);
二是先指定编码格式,然后用指定的编码格式去读取.
代码:
private static StringBuilder readFile(string filename)//读文件
{
StringBuilder sb = new StringBuilder();
System.Text.Encoding encode = System.Text.Encoding.GetEncoding("GB2312");
FileStream fs = null;
try
{
fs = File.OpenRead(@filename);
}
catch
{
return null;
}
byte[] arr = new byte[5000];
// UTF8Encoding data = new UTF8Encoding();
try
{
while (fs.Read(arr, 0, arr.Length) > 0)
{
sb.Append(encode.GetString(arr));
}
return sb;
}
catch
{
return null;
}
finally
{
fs.Close();
}
}
记事本的默认编码格式是ANSI,所以你用UTF8读取记事本文件的中文会乱码,
解决方法有两种:
一是用StreamRead去读,new的时候传出两个参数,第一个是路径
第二个是编码格式,你可以指定为枚举类型中的默认编码格式
StreamReader sr= new StreamReader(filename,Encoding.Default);
二是先指定编码格式,然后用指定的编码格式去读取.
代码:
private static StringBuilder readFile(string filename)//读文件
{
StringBuilder sb = new StringBuilder();
System.Text.Encoding encode = System.Text.Encoding.GetEncoding("GB2312");
FileStream fs = null;
try
{
fs = File.OpenRead(@filename);
}
catch
{
return null;
}
byte[] arr = new byte[5000];
// UTF8Encoding data = new UTF8Encoding();
try
{
while (fs.Read(arr, 0, arr.Length) > 0)
{
sb.Append(encode.GetString(arr));
}
return sb;
}
catch
{
return null;
}
finally
{
fs.Close();
}
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询