回覆列表
  • 1 # 使用者1811458706817

    檔案的字符集在Windows下有兩種,一種是ANSI,一種Unicode。對於Unicode,Windows支援了它的三種編碼方式,一種是小尾編碼(Unicode),一種是大尾編碼(BigEndianUnicode),一種是UTF-8編碼。我們可以從檔案的頭部來區分一個檔案是屬於哪種編碼。當頭部開始的兩個位元組為 FF FE時,是Unicode的小尾編碼;當頭部的兩個位元組為FEFF時,是Unicode的大尾編碼;當頭部兩個位元組為EF BB時,是Unicode的UTF-8編碼;當它不為這些時,則是ANSI編碼。按照如上所說,我們可以透過讀取檔案頭的兩個位元組來判斷檔案的編碼格式,程式碼如下(C#程式碼):程式中System.Text.Encoding.Default是指作業系統的當前 ANSI 內碼表的編碼。

    1: public System.Text.Encoding GetFileEncodeType(string filename)

    2: {

    3: System.IO.FileStream fs = new System.IO.FileStream(filename, System.IO.FileMode.Open, System.IO.FileAccess.Read);

    4: System.IO.BinaryReader br = new System.IO.BinaryReader(fs);

    5: Byte[] buffer = br.ReadBytes(2);

    6: if(buffer[0]>=0xEF)

    7: {

    8: if(buffer[0]==0xEF && buffer[1]==0xBB)

    9: {

    10: return System.Text.Encoding.UTF8;

    11: }

    12: else if(buffer[0]==0xFE && buffer[1]==0xFF)

    13: {

    14: return System.Text.Encoding.BigEndianUnicode;

    15: }

    16: else if(buffer[0]==0xFF && buffer[1]==0xFE)

    17: {

    18: return System.Text.Encoding.Unicode;

    19: }

    20: else21: { 22: return System.Text.Encoding.Default; 23: } 24: } 25: else26: { 27: return System.Text.Encoding.Default; 28: } 29: }

  • 2 # 已經過期了

    1、檔案編碼格式一般指檔案內文字字符采用什麼樣的字符集, 通常簡體中文windows採用GB2312,極個別文字字符采用utf-8字符集, 2、有時檔案編碼格式也通常指代檔案的型別,windows對程式或資料檔案的識別,一般透過副檔名來完成,也就是透過.

  • 中秋節和大豐收的關聯?
  • 為什麼感覺年味缺失了?