golang はどのようにファイルを読み取るのでしょうか?
golang でファイルを読み取る 4 つの方法
ファイルを読む
読み取ったファイルは file/test に配置されます。つまり、ファイル パッケージの下にあるテスト ファイルです。 、そこにさらにファイルを書き込みます
ファイルの読み取り方法 1: ioutil.ReadFile を使用してファイルから []byte
func Read0() (string){ f, err := ioutil.ReadFile("file/test") if err != nil { fmt.Println("read fail", err) } return string(f) }
ファイルの読み取り方法 2: 最初にファイルからファイルに読み取りますファイルから buf への読み取り時に、buf が最後の []byte
func Read1() (string){ //获得一个file f, err := os.Open("file/test") if err != nil { fmt.Println("read fail") return "" } //把file读取到缓冲区中 defer f.Close() var chunk []byte buf := make([]byte, 1024) for { //从file读取到buf中 n, err := f.Read(buf) if err != nil && err != io.EOF{ fmt.Println("read buf fail", err) return "" } //说明读取结束 if n == 0 { break } //读取到最终的缓冲区中 chunk = append(chunk, buf[:n]...) } return string(chunk) //fmt.Println(string(chunk)) }
ファイルの読み取り方法 3: 最初にファイルからファイルへ読み取り、次にファイルから Reader へ読み取り、Reader から読み取り buf、buf に追加されます。最後に []byte
//先从文件读取到file, 在从file读取到Reader中,从Reader读取到buf, buf最终追加到[]byte,这个排第三 func Read2() (string) { fi, err := os.Open("file/test") if err != nil { panic(err) } defer fi.Close() r := bufio.NewReader(fi) var chunks []byte buf := make([]byte, 1024) for { n, err := r.Read(buf) if err != nil && err != io.EOF { panic(err) } if 0 == n { break } //fmt.Println(string(buf)) chunks = append(chunks, buf...) } return string(chunks) //fmt.Println(string(chunks)) }
ファイルを読み取る 4 番目の方法: ファイルを読み取り、ioutil を使用してファイルを []byte
//读取到file中,再利用ioutil将file直接读取到[]byte中, 这是最优 func Read3() (string){ f, err := os.Open("file/test") if err != nil { fmt.Println("read file fail", err) return "" } defer f.Close() fd, err := ioutil.ReadAll(f) if err != nil { fmt.Println("read to fd fail", err) return "" } return string(fd) }
に直接読み取ります。読み取り速度の比較
テストの結果、これら 4 つの方法の読み取り速度ランキングは次のとおりです: 前者の方が優れています
方法 4>方法 1>方法 3>方法 4
ファイルの書き込み
ファイルを書き込む方法 1: io.WriteString を使用してファイルを書き込みます
func Write0() { fileName := "file/test1" strTest := "测试测试" var f *os.File var err error if CheckFileExist(fileName) { //文件存在 f, err = os.OpenFile(fileName, os.O_APPEND, 0666) //打开文件 if err != nil{ fmt.Println("file open fail", err) return } }else { //文件不存在 f, err = os.Create(fileName) //创建文件 if err != nil { fmt.Println("file create fail") return } } //将文件写进去 n, err1 := io.WriteString(f, strTest) if err1 != nil { fmt.Println("write error", err1) return } fmt.Println("写入的字节数是:", n) }
ファイルを書き込む方法 2: ioutil.WriteFile を使用してファイルを書き込みます
func Write1() { fileName := "file/test2" strTest := "测试测试" var d = []byte(strTest) err := ioutil.WriteFile(fileName, d, 0666) if err != nil { fmt.Println("write fail") } fmt.Println("write success") }
ファイルを書き込む 3 番目の方法: File(Write,WriteString) を使用してファイルを書き込みます
func Write2() { fileName := "file/test3" strTest := "测试测试" var d1 = []byte(strTest) f, err3 := os.Create(fileName) //创建文件 if err3 != nil{ fmt.Println("create file fail") } defer f.Close() n2, err3 := f.Write(d1) //写入文件(字节数组) fmt.Printf("写入 %d 个字节n", n2) n3, err3 := f.WriteString("writesn") //写入文件(字节数组) fmt.Printf("写入 %d 个字节n", n3) f.Sync() }
ファイルを書き込む 4 番目の方法: bufio.NewWriter を使用してファイルを書き込みます
func Write3() { fileName := "file/test3" f, err3 := os.Create(fileName) //创建文件 if err3 != nil{ fmt.Println("create file fail") } w := bufio.NewWriter(f) //创建新的 Writer 对象 n4, err3 := w.WriteString("bufferedn") fmt.Printf("写入 %d 个字节n", n4) w.Flush() f.Close() }
ファイルが存在するかどうかを確認します:
func CheckFileExist(fileName string) bool { _, err := os.Stat(fileName) if os.IsNotExist(err) { return false } return true }
golang の知識について詳しくは、PHP 中国語 Web サイトの golang チュートリアル 列を参照してください。
以上がgolangでファイルを読む方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。