加 Golang学习 QQ群共同学习进步成家立业工作 ^-^ 群号:96933959
文件读取
os.File 封装了文件相关操作
os.File Pkg Doc
读写参数
文件打开模式:
const ( O_RDONLY int = syscall.O_RDONLY // 只读模式打开文件 O_WRONLY int = syscall.O_WRONLY // 只写模式打开文件 O_RDWR int = syscall.O_RDWR // 读写模式打开文件 O_APPEND int = syscall.O_APPEND // 写操作时将数据附加到文件尾部 O_CREATE int = syscall.O_CREAT // 如果不存在将创建一个新文件 O_EXCL int = syscall.O_EXCL // 和O_CREATE配合使用,文件必须不存在 O_SYNC int = syscall.O_SYNC // 打开文件用于同步I/O O_TRUNC int = syscall.O_TRUNC // 如果可能,打开时清空文件 )
权限控制:
r ——> 004 w ——> 002 x ——> 001
读取栗子
os.Open || os.OpenFile
package main import ( "bufio" "fmt" "os" ) func main() { // file, err := os.Open("/tmp/test") file, err := os.OpenFile("/tmp/test", os.O_CREATE|os.O_WRONLY, 0666) if err != nil { fmt.Println("Open file error: ", err) return } defer file.Close() //关闭文件 reader := bufio.NewReader(file) //带缓冲区的读写 for { str, err := reader.ReadString('\n') // 循环读取一行 if err != nil { fmt.Println("read string failed, err: ", err) return } fmt.Println("read string is %s: ", str) } }
readline
package main import ( "bufio" "fmt" "io" "os" ) func main() { file, err := os.Open("C:/test.log") if err != nil { fmt.Println(err) return } defer file.Close() reader := bufio.NewReader(file) var line []byte for { data, prefix, err := reader.ReadLine() if err == io.EOF { break } line = append(line, data...) if !prefix { fmt.Printf("data:%s\n", string(line)) line = line[:] } } }
读取整个文件栗子
"io/ioutil" 包实现了读取整个文件功能
package main import ( "fmt" "os" "io/ioutil" ) func main() { fileName := "/tmp/test" file, err := os.OpenFile(fileName, os.O_CREATE|os.O_RDWR, 0666) if err != nil { fmt.Println("Open file error: ", err) return } defer file.Close() buf, err := ioutil.ReadAll(file) //buf, err := ioutil.ReadFile(fileName) if err != nil { fmt.Fprintf(os.Stderr, "File Error: %s\n", err) return } fmt.Printf("%s\n", string(buf)) }
读取压缩文件栗子
"compress/*" 包实现压缩文件功能。
"compress/gzip" 包实现了gzip格式压缩文件的读写
package main import ( "bufio" "compress/gzip" "fmt" "os" ) func main() { fileName := "/tmp/test.log.gz" var r *bufio.Reader fi, err := os.Open(fileName) if err != nil { fmt.Println("error", err) os.Exit(1) } fz, err := gzip.NewReader(fi) if err != nil { fmt.Println("error", err) return } r = bufio.NewReader(fz) for { line, err := r.ReadString('\n') if err != nil { fmt.Println("Done reading file") return } fmt.Println(line) } }
文件写入
file.WriteString || file.Write
package main import ( "fmt" "os" ) func main() { fileName := "/tmp/test_write" file, err := os.OpenFile(fileName, os.O_CREATE|os.O_WRONLY, 0755) if err != nil { fmt.Println("error", err) os.Exit(1) } defer file.Close() fileString := "Today very happy." file.Seek(0, 2) // 最后增加 file.WriteString(fileString) //file.Write([]byte(fileString)) }
bufio.Writer.WriteString
带缓冲的写,最后要将缓冲中的数据写入下层的io.Writer接口(Flush方法)
package main import ( "bufio" "fmt" "os" ) func main() { fileName := "/tmp/test_write" file, err := os.OpenFile(fileName, os.O_CREATE|os.O_WRONLY, 0755) if err != nil { fmt.Println("error", err) os.Exit(1) } defer file.Close() fileWrite := bufio.NewWriter(file) fileString := "good.\n" for i := 0; i < 10; i++ { fileWrite.WriteString(fileString) } fileWrite.Flush() }
拷贝文件栗子
从一个文件拷贝到另一个文件
package main import ( "fmt" "io" "os" ) func CopyFile(dstName, srcName string) (writeen int64, err error) { src, err := os.Open(dstName) if err != nil { fmt.Println(err) return } defer src.Close() dst, err := os.OpenFile(srcName, os.O_CREATE|os.O_WRONLY, 0644) if err != nil { fmt.Println(err) return } defer dst.Close() return io.Copy(dst, src) } func main() { CopyFile("/tmp/test", "/tmp/test_copy1") fmt.Println("copy done.") }
栗子
判断文件或文件夹是否存在
func PathExists(path string) (bool, error) { /* 判断文件或文件夹是否存在 如果返回的错误为nil,说明文件或文件夹存在 如果返回的错误类型使用os.IsNotExist()判断为true,说明文件或文件夹不存在 如果返回的错误为其它类型,则不确定是否在存在 */ _, err := os.Stat(path) if err == nil { return true, nil } if os.IsNotExist(err) { return false, nil } return false, err }