今天測試開啟文字檔案時發生亂碼,用 Notepad++
開啟後發現該檔案編碼是 big5
,心想著簡單那就用 Encoding.GetEncoding(950)
來開起就好了,誰知道撞璧了…
測試中發現原來 .NET Core 預設支援的編碼不多,比較如下:
- .NETFramework v4.6.1
12345678910var encodings = Encoding.GetEncodings();foreach (var item in encodings){Console.WriteLine($"DisplayNameitem={item.DisplayName}, CodePage={item.CodePage}");}Console.WriteLine($"Count={encodings.Count()}");Console.ReadKey();
- .NET Core 2.1
12345678910var encodings = Encoding.GetEncodings();foreach (var item in encodings){Console.WriteLine($"DisplayNameitem={item.DisplayName}, CodePage={item.CodePage}");}Console.WriteLine($"Count={encodings.Length}");Console.ReadKey();
測試完才發現原來 .NET Core 簡化了這麼多編碼,查了資料後得知微軟把編碼移植到 System.Text.Encoding.CodePages 拆分到 NuGet 了,需要的話可以自行下載。
安裝後加上 Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);
即可,測試結果如下:
1 2 3 4 5 |
var encoding = Encoding.GetEncoding(950); Console.WriteLine($"DisplayNameitem={encoding.EncodingName}, CodePage={encoding.CodePage}"); Console.ReadKey(); |
參考資料: