1. 读文件
1.1 使用ioutil
直接读取
需要引入io/ioutil
包,该包默认拥有以下函数供用户调用。
func NopCloser(r io.Reader) io.ReadCloser
func ReadAll(r io.Reader) ([]byte, error)
func ReadDir(dirname string) ([]os.FileInfo, error)
func ReadFile(filename string) ([]byte, error)
func TempDir(dir, prefix string) (name string, err error)
func TempFile(dir, prefix string) (f *os.File, err error)
func WriteFile(filename string, data []byte, perm os.FileMode) error
//从一个io.Reader类型中读取内容直到返回错误或者EOF时返回读取的数据,当err == nil时,数据成功读取到[]byte中ReadAll函数被定义为从源中读取数据直到EOF,它是不会去从返回数据中去判断EOF来作为读取成功的依据
func ReadAll(r io.Reader) ([]byte, error)
//读取一个目录,并返回一个当前目录下的文件对象列表和错误信息
func ReadDir(dirname string) ([]os.FileInfo, error)
//读取文件内容,并返回[]byte数据和错误信息。err == nil时,读取成功
func ReadFile(filename string) ([]byte, error)
读取文件和读目录示例:
package main
import (
"fmt"
"io/ioutil"
"strings"
)
var (
myReadFile = "my_read_file.txt"
)
func main() {
Ioutil(myReadFile)
// test ioutil.ReadDir function
dirname := "/home/work/xs_golang/file_operation"
testReadDir(dirname)
}
func Ioutil(name string) {
if contents, err := ioutil.ReadFile(name); err == nil {
//因为contents是[]byte类型,直接转换成string类型后会多一行空格,需要使用strings.Replace替换换行符
result := strings.Replace(string(contents), "\n", "", 1)
fmt.Println(result)
}
}
func testReadDir(dirname string) error {
fmt.Printf("file under directory: %s as follows:\n", dirname)
fileInfoList, err := ioutil.ReadDir(dirname)
if err != nil {
fmt.Printf("ioutil.ReadDir failed. err: %v\n", err)
return err
}
for index, fileInfo := range fileInfoList {
fmt.Printf("%d\t%s\n", index, fileInfo.Name())
}
return nil
}
1.2 借助os.Open
进行读取文件
1.2.1 借助os.Open和ioutil.ReadAll读取文件
由于os.Open是打开一个文件并返回一个文件对象,因此其实可以结合ioutil.ReadAll(r io.Reader)来进行读取。 io.Reader其实是一个包含Read方法的接口类型,而文件对象本身是实现了了Read方法的。
我们先来看下os.Open家族的相关函数
//打开一个需要被读取的文件,如果成功读取,返回的文件对象将可用被读取,该函数默认的权限为O_RDONLY,也就是只对文件有只读权限。如果有错误,将返回*PathError类型
func Open(name string) (*File, error)
//大部分用户会选择该函数来代替Open or Create函数。该函数主要用来指定参数(os.O_APPEND|os.O_CREATE|os.O_WRONLY)以及文件权限(0666)来打开文件,如果打开成功返回的文件对象将被用作I/O操作
func OpenFile(name string, flag int, perm FileMode) (*File, error)