Golang之文件操作

无人久伴 提交于 2020-03-22 11:50:04

3 月,跳不动了?>>>

1. 相关api介绍

  • 建立File内存地址api
//返回File的内存地址,错误信息,通过os库调用
func Create(name string) (file *File, err Error)
//返回文件的内存地址,通过os库调用
func NewFile(fd int, name string) *File
  • 打开文件api
//返回File的内存地址,错误信息,通过os库调用
func Open(name string) (file *File, err Error)
//返回File的内存地址,错误信息,通过os库调用
func OpenFile(name string, flag int, perm unit32) (file *File, err Error)
  • 写文件api
//写入一个slice,返回写的个数,错误信息,通过File的内存地址调用
func (file *File) Write(b []byte) (n int, err Error)
//从slice的某个位置开始写入,返回写的个数,错误信息,通过File的内存地址调用
func (file *File) WriteAt(b []byte, off int64) (n int, err Error)
//写入一个字符串,返回写的个数,错误信息,通过File的内存地址调用
func (file *File) WriteString(s string) (ret int, err Error)
  • 读文件api
//读取一个slice,返回读的个数,错误信息,通过File的内存地址调用
func (file *File) Read(b []byte) (n int, err Error)
//从slice的某个位置开始读取,返回读到的个数,错误信息,通过File的内存地址调用
func (file *File) ReadAt(b []byte, off int64) (n int, err Error)
  • 删除文件api
//传入文件的路径来删除文件,返回错误个数
func Remove(name string) Error

2. 写文件的实例代码

编写代码vim main.go

package main

import (
	"fmt"
	"os"
)

func main() {
	myFile := "./abc.txt"
	fout, err := os.Create(myFile) //fout,	err := os.OpenFile(myFile,os.O_CREATE,0644)
	if err != nil {
		fmt.Println(err)
		return
	}
	for i := 0; i < 5; i++ {
		outstr := fmt.Sprintf("%s:%d\n", "Hello world", i)
		fout.WriteString(outstr)
		fout.Write([]byte("abcd\n"))
	}
	fout.Close()
}

执行代码:go run main.go

成功: 进程退出代码 0.

查看输出文件:cat abc.txt

Hello world:0
abcd
Hello world:1
abcd
Hello world:2
abcd
Hello world:3
abcd
Hello world:4
abcd

3. 读文件的实例代码

package main

import (
	"fmt"
	"os"
)

func test_read_file(filename string) {
	fin, err := os.Open(filename)
	if err != nil {
		fmt.Println(err)
	}
	defer fin.Close()
	buf := make([]byte, 1024) //开辟1024个字节的slice作为缓冲
	for {
		n, _ := fin.Read(buf)
		if n == 0 { //0	表示到达EOF
			break
		}
		os.Stdout.Write(buf)
	}
}
func main() {
	test_read_file("./abc.txt")
}

4. 同时使用os.Open和os.Create操作文件

package main

import (
	"io"
	"os"
)

func main() {
	fi, err := os.Open("./abc.txt") //打开输入*File
	if err != nil {
		panic(err)
	}
	defer fi.Close()
	fo, err := os.Create("./abc_new.txt") //创建输出*File
	if err != nil {
		panic(err)
	}
	defer fo.Close()
	buf := make([]byte, 1024)
	for {
		n, err := fi.Read(buf) //从input.txt读取
		if err != nil && err != io.EOF {
			panic(err)
		}
		if n == 0 {
			break
		}
		if n2, err := fo.Write(buf[:n]); err != nil {
			//写入output .txt,直到错误
			panic(err)
		} else if n2 != n {
			panic("error	in	writing")
		}
	}
}

5. 使用bufio库来操作文件读写

package main

import (
	"bufio"
	"io"
	"os"
)

func main() {
	fi, err := os.Open("input.txt") //打开输入*File
	if err != nil {
		panic(err)
	}
	defer fi.Close()
	r := bufio.NewReader(fi)           //创建一个读取缓冲流
	fo, err := os.Create("output.txt") //创建输出*File
	if err != nil {
		panic(err)
	}
	defer fo.Close()
	w := bufio.NewWriter(fo) //创建输出缓冲流
	buf := make([]byte, 1024)
	for {
		n, err := r.Read(buf)
		if err != nil && err != io.EOF {
			panic(err)
		}
		if n == 0 {
			break
		}
		if n2, err := w.Write(buf[:n]); err != nil {
			panic(err)
		} else if n2 != n {
			panic("error	in	writing")
		}
	}
	if err = w.Flush(); err != nil {
		panic(err)
	}
}

6. 使用ioutil来读写文件

package main

import (
	"io/ioutil"
)

func main() {
	b, err := ioutil.ReadFile("input.txt") //读文件
	if err != nil {
		panic(err)
	}
	err = ioutil.WriteFile("output.txt", b, 0644) //写文件
	if err != nil {
		panic(err)
	}
}

7. 遍历文件夹

package main

import (
	"flag"
	"fmt"
	"os"
	"path/filepath"
)

func getFilelist(path string) {
	err := filepath.Walk(path, func(path string, f os.FileInfo, err error) error {
		if f == nil {
			return err
		}
		if f.IsDir() {
			return nil
		}
		println(path)
		return nil
	})

	if err != nil {
		fmt.Printf("filepath.Walk()	returned	%v\n", err)
	}
}
func main() {
	flag.Parse()
	root := flag.Arg(0)
	getFilelist(root)
}
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!