如果我使用FileIO.ReadTextAsync,ReadLinesAsync或DataReader读取文本文件,我只能为编码指定UnicodeEncoding枚举的成员。这包括出于某种原因只有Utf8,Utf16BE和Utf16LE。如何使用其他编码(如Windows-1252或甚至常规Unicode(所有字符均为2字节))读取文本文件?)
如果Windows应用商店应用与桌面应用共享文本文件或从互联网上读取文本文件,这可能很重要。
答案 0 :(得分:4)
汉斯的评论实际上给出了我的问题的答案。适用于Windows-1252的示例:
string filePath = ...
StorageFile file = await StorageFile.GetFileFromPathAsync(filePath);
IBuffer buffer = await FileIO.ReadBufferAsync(file);
byte[] fileData = buffer.ToArray();
Encoding encoding = Encoding.GetEncoding("Windows-1252");
string text = encoding.GetString(fileData, 0, fileData.Length);
答案 1 :(得分:0)
@JürgenBayerbuffer.ToArray()
无法使用。
所以,而不是写作:
string text = await FileIO.ReadTextAsync(file);
我写道:
IBuffer buffer = await FileIO.ReadBufferAsync(file);
byte[] fileData;
CryptographicBuffer.CopyToByteArray(buffer, out fileData);
Encoding encoding = Encoding.GetEncoding("Windows-1252");
string text = encoding.GetString(fileData, 0, fileData.Length);