读写文件是最基本的功能。
go语言读文件挺有意思,由于go语言的interface,使得go语言与其他语言有所不同。与其他语言一样,go语言有File类型的结构体,但File只提供了最基本的Read,Write等功能,而类似 与ReadLine这样的功能实在bufio包里提供的。
1,使用最传统的方式,Open,Read,Close,代码如下:
package main import ( "fmt" "os" ) func main() { f, err := os.Open("d:\\test.txt") if err != nil { panic("open failed!") } defer f.Close() buff := make([]byte, 1024) for n, err := f.Read(buff); err == nil; n, err = f.Read(buff) { fmt.Print(string(buff[:n])) } if err != nil { panic(fmt.Sprintf("Read occurs error: %s", err)) } }
2,使用ioutil
package main import ( "fmt" "io/ioutil" ) func main() { buff, err := ioutil.ReadFile("d:\\test.txt") if err != nil { panic("open file failed!") } fmt.Print(string(buff)) }
ioutil非常简单,一次把文件的所有内容都读出来。如果文件较大,会占用很多内存,需要小心。
3,使用bufio,源代码http://golang.org/src/pkg/bufio/bufio.go
package main import ( "bufio" "fmt" "io" "os" ) func main() { f, err := os.Open("d:\\test.txt") if err != nil { panic("open failed!") } defer f.Close() b := bufio.NewReader(f) line, err := b.ReadString('\n') for ; err == nil; line, err = b.ReadString('\n') { fmt.Print(line) } if err == io.EOF { fmt.Print(line) } else { panic("read occur error!") } }
bufio提供了很多操作,例如ReadString,ReadBytes,ReadSlice,ReadLine,使用ReadSlice和ReadLine需要小心:
1、ReadSlice和ReadLine返回的[]byte并非copy的一份副本,因此,下一次ReadSlice时,这个值就变了
2、ReadLine除了上面的问题外,ReadLine返回的数据不包括回车符\n和换行符\r
具体的可以参考bufio的注释,写的很清楚。
其实,ReadSting和ReadBytes已经非常好用,这两个方法的参数都是分隔符,当读到分隔符时,函数就返回。