Dateien mit BOM in Go lesen
Frage:
Wie kann ich Unicode-Dateien lesen? Enthält oder fehlen Byte-Order-Markierungen (BOMs) in Go? Gibt es eine Standardmethode, um damit umzugehen?
Antwort:
Die Standardbibliotheken von Go bieten keine spezielle Methode für die Stücklistenverwaltung. Hier sind zwei Ansätze, um diese Funktionalität selbst zu implementieren:
Buffered Reader Approach:
Das bufio-Paket bietet eine praktische Lösung für die Handhabung von Stücklisten. Sie können einen gepufferten Reader um Ihren Datenstrom wickeln und die erste Rune überprüfen:
<code class="go">import ( "bufio" "os" ) func main() { fd, err := os.Open("filename") if err != nil { // Handle error } br := bufio.NewReader(fd) r, _, err := br.ReadRune() if err != nil { // Handle error } if r != '\uFEFF' { br.UnreadRune() // Not a BOM -- put the rune back } }</code>
Wenn die erste Rune keine Stückliste ist, können Sie wie erwartet mit dem Lesen aus dem gepufferten Reader fortfahren.
Seeker-Schnittstellenansatz:
Für Objekte, die die io.Seeker-Schnittstelle implementieren (z. B. os.File), können Sie dies überprüfen die ersten drei Bytes direkt und suchen Sie zurück zum Anfang, wenn kein BOM vorhanden ist:
<code class="go">import ( "os" ) func main() { fd, err := os.Open("filename") if err != nil { // Handle error } bom := [3]byte _, err = io.ReadFull(fd, bom[:]) if err != nil { // Handle error } if bom[0] != 0xef || bom[1] != 0xbb || bom[2] != 0xbf { _, err = fd.Seek(0, 0) // Not a BOM -- seek back to the beginning if err != nil { // Handle error } } }</code>
Beachten Sie, dass dieser Ansatz eine UTF-8-Codierung voraussetzt. Für andere Kodierungen ist eine komplexere Handhabung erforderlich.
Das obige ist der detaillierte Inhalt vonWie lese ich Unicode-Dateien mit und ohne Stücklisten in Go?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!