涉及到文件、文件夹操作包
- os
- io
- bufio
- io/ioutil
- filepath //文件夹
文件存在判断 #
func CheckFileExist(filename string) bool {
	_,err := os.Stat(filename);
	if  err != nil {
		if os.IsNotExist(err) {
			return false
		}
	}
	return true
}
文件读取操作 #
通过io/ioutil读取文件内容 #
func ReadFileOne(filename string) []byte  {
	content, err := ioutil.ReadFile(filename)
	if err != nil {
		return []byte("")
	}
	return content
}
通过file打开文件 #
fp,err := os.Open(filename)
defer fp.Close()
buf := make([]byte,1024)
//通过fp.Read读取文件
n,_ := fp.Read(buf)
return buf[:n]
//通过io.ReadAll读取文件内容
buf := make([]byte,1024)
io.ReadAll(fp)
io.ReadFull(fp,buf)
//通过bufio缓冲区读取文件
1、
reader := bufio.NewReader(fp)
str,err := reader.ReadString('\n')
2、
buf := make([]byte,1024)
reader.Read(buf)
content = append(content,buf[:n]...)
文件写入操作 #
通过ioutil包写入 #
	err := ioutil.WriteFile(filename,[]byte(data),0666)
通过file操作文件写入 #
fp, err = os.OpenFile(filename,os.O_APPEND|os.O_WRONLY,0666)
fp, err = os.Create(filename)
1、通过fp句柄
_, err = fp.WriteString(data)
2、通过io包
_,err = io.WriteString(fp,data)
3、通过bufio Writer
writer := bufio.NewWriter(fp)
writer.WriteString(data) //写入string
writer.Write([]byte)     //写入字节切片
writer.Flush()  //要刷新缓冲区
	
函数说明 #
删除文件
os.Remove(fname)
创建目录
os.Mkdir(dname, os.ModeDir|os.ModePerm)
创建完整目录路径
os.MkdirAll(dname,os.ModeDir|os.ModePerm)
以只读方式打开一个存在的文件,打开就可以读取了
func Open(name string) (file *File, err error)
func OpenFile(name string, flag int, perm FileMode) (file *File, err error)
直接通过纹面创建文件
func Create(name string) (file *File, err error)
func NewFile(fd uintptr, name string) *File
以只读方式打开一个存在的文件,打开就可以读取了
func Open(name string) (file *File, err error)
func OpenFile(name string, flag int, perm FileMode) (file *File, err error)
管道
func Pipe() (r *File, w *File, err error)
改变当前的工作目录
func (f *File) Chdir() error
改变权限
func (f *File) Chmod(mode FileMode) error
改变所有者
func (f *File) Chown(uid, gid int) error
关闭文件
func (f *File) Close() error
返回文件句柄
func (f *File) Fd() uintptr
返回文件名
func (f *File) Name() string
读取文件
func (f *File) Read(b []byte) (n int, err error)
从off开始读取文件
func (f *File) ReadAt(b []byte, off int64) (n int, err error)
读取文件目录返回n个fileinfo
func (f *File) Readdir(n int) (fi []FileInfo, err error)
读取文件目录返回n个文件名
func (f *File) Readdirnames(n int) (names []string, err error)
设置读写文件的偏移量,whence为0表示相对于文件的开始处,1表示相对于当前的位置,2表示相对于文件结尾。他返回偏移量。如果有错误返回错误
func (f *File) Seek(offset int64, whence int) (ret int64, err error)
返回当前文件fileinfo结构体
func (f *File) Stat() (fi FileInfo, err error)
把当前内容持久化,一般就是马上写入到磁盘
func (f *File) Sync() (err error)
改变当前文件的大小,他不改变当前文件读写的偏移量
func (f *File) Truncate(size int64) error
写入内容
func (f *File) Write(b []byte) (n int, err error)
在offset位置写入内容
func (f *File) WriteAt(b []byte, off int64) (n int, err error)
写入字符
func (f *File) WriteString(s string) (ret int, err error)
Path包 #
 //返回路径的最后一个元素
    fmt.Println(path.Base("./a/b/c"));
    //如果路径为空字符串,返回.
    fmt.Println(path.Base(""));
    //如果路径只有斜线,返回/
    fmt.Println(path.Base("///"));
 
    //返回等价的最短路径
    //1.用一个斜线替换多个斜线
    //2.清除当前路径.
    //3.清除内部的..和他前面的元素
    //4.以/..开头的,变成/
    fmt.Println(path.Clean("./a/b/../"));
 
    //返回路径最后一个元素的目录
    //路径为空则返回.
    fmt.Println(path.Dir("./a/b/c"));
 
    //返回路径中的扩展名
    //如果没有点,返回空
    fmt.Println(path.Ext("./a/b/c/d.jpg"));
 
    //判断路径是不是绝对路径
    fmt.Println(path.IsAbs("./a/b/c"));
    fmt.Println(path.IsAbs("/a/b/c"));
 
    //连接路径,返回已经clean过的路径
    fmt.Println(path.Join("./a", "b/c", "../d/"));
 
    //匹配文件名,完全匹配则返回true
    fmt.Println(path.Match("*", "a"));
    fmt.Println(path.Match("*", "a/b/c"));
    fmt.Println(path.Match("\\b", "b"));
 
    //分割路径中的目录与文件
    fmt.Println(path.Split("./a/b/c/d.jpg"));
filepath包 #
   //返回所给路径的绝对路径
    path, _ := filepath.Abs("./1.txt");
    fmt.Println(path);
 
    //返回路径最后一个元素
    fmt.Println(filepath.Base("./1.txt"));
    //如果路径为空字符串,返回.
    fmt.Println(filepath.Base(""));
    //如果路径只有斜线,返回/
    fmt.Println(filepath.Base("///"));
 
    //返回等价的最短路径
    //1.用一个斜线替换多个斜线
    //2.清除当前路径.
    //3.清除内部的..和他前面的元素
    //4.以/..开头的,变成/
    fmt.Println(filepath.Clean("C:/a/b/../c"));
    fmt.Println(filepath.Clean("./1.txt"));
 
    //返回路径最后一个元素的目录
    //路径为空则返回.
    fmt.Println(filepath.Dir("./a/b/c"));
    fmt.Println(filepath.Dir("C:/a/b/c"));
 
    //返回链接文件的实际路径
    path2, _ := filepath.EvalSymlinks("1.lnk");
    fmt.Println(path2);
 
    //返回路径中的扩展名
    //如果没有点,返回空
    fmt.Println(filepath.Ext("./a/b/c/d.jpg"));
 
    //将路径中的/替换为路径分隔符
    fmt.Println(filepath.FromSlash("./a/b/c"));
 
    //返回所有匹配的文件
    match, _ := filepath.Glob("./*.go");
    fmt.Println(match);
 
    //判断路径是不是绝对路径
    fmt.Println(filepath.IsAbs("./a/b/c"));
    fmt.Println(filepath.IsAbs("C:/a/b/c"));
 
    //连接路径,返回已经clean过的路径
    fmt.Println(filepath.Join("C:/a", "/b", "/c"));
 
    //匹配文件名,完全匹配则返回true
    fmt.Println(filepath.Match("*", "a"));
    fmt.Println(filepath.Match("*", "C:/a/b/c"));
    fmt.Println(filepath.Match("\\b", "b"));
 
    //返回以basepath为基准的相对路径
    path3, _ := filepath.Rel("C:/a/b", "C:/a/b/c/d/../e");
    fmt.Println(path3);
 
    //将路径使用路径列表分隔符分开,见os.PathListSeparator
    //linux下默认为:,windows下为;
    fmt.Println(filepath.SplitList("C:/windows;C:/windows/system"));
 
    //分割路径中的目录与文件
    dir, file := filepath.Split("C:/a/b/c/d.jpg");
    fmt.Println(dir, file);
 
    //将路径分隔符使用/替换
    fmt.Println(filepath.ToSlash("C:/a/b"));
 
    //返回分区名
    fmt.Println(filepath.VolumeName("C:/a/b/c"));
 
    //遍历指定目录下所有文件
    filepath.Walk("./", func(path string, info os.FileInfo, err error) error {
        fmt.Println(path);
        return nil;
    });