2 回答

TA貢獻1811條經驗 獲得超4個贊
bufio.ReadString讀取直到輸入中第一次出現delim為止,返回一個字符串,其中包含直到定界符(包括定界符)的數據。如果ReadString在找到定界符之前遇到錯誤,它將返回錯誤之前讀取的數據和錯誤本身(通常為io.EOF)。當且僅當返回的數據未以delim結尾時,ReadString才返回err!= nil。
如果buf.ReadString('\n')返回的錯誤不是io.EOF,例如bufio.ErrBufferFull,您將陷入無限循環。另外,如果文件未以結尾,則'\n'在last后面靜默忽略數據'\n'。
這是一個更強大的解決方案,僅執行buf.ReadString('\n')一次。
package main
import (
"bufio"
"fmt"
"io"
"os"
"strings"
)
func main() {
filename := "FileName"
file, err := os.Open(filename)
if err != nil {
fmt.Println(err)
return
}
defer file.Close()
buf := bufio.NewReader(file)
for {
line, err := buf.ReadString('\n')
if err != nil {
if err != io.EOF || len(line) > 0 {
fmt.Println(err)
return
}
break
}
fmt.Println(strings.TrimRight(line, "\n"))
}
}

TA貢獻1818條經驗 獲得超3個贊
不逐行讀取可以改善大多數逐行讀取的代碼。如果您的目標是讀取文件并訪問行,則以下內容通??偸歉谩?/p>
package main
import (
"fmt"
"io/ioutil"
"log"
"strings"
)
func main() {
b, err := ioutil.ReadFile("filename")
if err != nil {
log.Fatal(err)
}
s := string(b) // convert []byte to string
s = strings.TrimRight(s, "\n") // strip \n on last line
ss := strings.Split(s, "\n") // split to []string
for _, s := range ss {
fmt.Println(s)
}
}
任何錯誤都在同一時刻出現,因此簡化了錯誤處理。如Peter所建議的那樣,在最后一行中刪除換行符可允許文件具有或不具有最后一個換行符。如今,與可用內存相比,大多數文本文件很小,因此一口氣讀取它們是合適的。
- 2 回答
- 0 關注
- 202 瀏覽
添加回答
舉報