如何使用streamreader使用当前编码读取byte []

时间:2013-05-16 21:46:09

标签: c# .net encoding stream streamreader

我想使用C#和文件的当前编码来阅读byte[]

如MSDN中所写,当构造函数没有编码时,默认编码为UTF-8:

var reader = new StreamReader(new MemoryStream(data)).

我也试过这个,但仍然把文件作为UTF-8:

var reader = new StreamReader(new MemoryStream(data),true)

我需要使用当前编码读取byte[]

2 个答案:

答案 0 :(得分:9)

文件没有编码。字节数组没有编码。一个字节没有编码。编码是将字节转换为文本的内容,反之亦然。

你在文本编辑器等中看到的实际上是程序魔术:编辑器尝试不同的编码然后猜测哪一个最有意义。这也是您使用boolean参数启用的内容。如果这不能产生你想要的东西,那么这种魔力就会失败。

var reader = new StreamReader(new MemoryStream(data), Encoding.Default);

将使用OS / Location特定的默认编码。如果那还不是你想要的,那么你需要完全明确,并告诉streamreader要使用的确切编码,例如(就像一个例子,你说你不想要UTF8):

var reader = new StreamReader(new MemoryStream(data), Encoding.UTF8);

答案 1 :(得分:0)

我只是尝试利用不同的方法来尝试找出ByteEncoding,并且不可能这样做,因为字节数组没有像Jan在他的回复中提到的编码。但是,您总是可以获取值并进行类型转换为UTF8或ASCII / Unicode并测试字符串值,以防您执行" Text.EncodingFormat.GetString(byte []数组)"

s