本文主要讲述os.Mkdir、os.MkdirAll区别以及在创建文件目录过程中的一些其他技巧。

 os.Mkdir("abc", os.ModePerm)              //创建目录   
 os.MkdirAll("dir1/dir2/dir3", os.ModePerm)   //创建多级目录   

首先,试图从一个Go可执行文件创建一组嵌套目录(如’dir1/dir2/dir3’),并打印错误出来看看。

err:=os.Mkdir(“dir1/dir2/dir3”,os.ModePerm)
if err!=nil{
 	fmt.Println(err) 
}
result:mkdir ./dir1/dir2/dir3: The system cannot find the path specified.

Mkdir 用于创建单个目录。

err:=os.Mkdir("./dir1",os.ModePerm)
if err!=nil{
   fmt.Println(err)
}

初次创建dir1时成功,再次创建dir1时,如果path已经是一个目录,Mkdir会报错

mkdir ./dir1: Cannot create a file when that file already exists.

根据日期创建文件夹

import (
    "os"
    "path/filepath"
    "time"
)
// CreateDateDir 根据当前日期来创建文件夹
func CreateDateDir(Path string) string {
    folderName := time.Now().Format("20060102")
    folderPath := filepath.Join(Path, folderName)
    if _, err := os.Stat(folderPath); os.IsNotExist(err) {
        // 必须分成两步:先创建文件夹、再修改权限
        os.Mkdir(folderPath, 0777) //0777也可以os.ModePerm
        os.Chmod(folderPath, 0777)
	}
    return folderPath
}

创建文件夹路径,请使用os.MkdirAll(folderPath,os.ModePerm)

err=os.MkdirAll("./dir1/dir2",os.ModePerm)
if err!=nil{
   fmt.Println(err)
   }
err为nil
成功创建dir1/dir2文件路径

MkdirAll会创建一个名为path的目录以及任何必要的父项,并返回nil,否则返回错误。许可位perm用于MkdirAll创建的所有目录。如果path已经是一个目录,MkdirAll什么也不做,并返回nil。
根据日期创建文件夹路径

uploadDir := "static/upload/" + time.Now().Format("2006/01/02/")
err := os.MkdirAll( uploadDir , 777)

其他os包中的一些常用函数:

os.Getwd()   //获取当前目录

创建文件

f1, _ := os.Create("./1.txt") 
defer f1.Close()

以读写方式打开文件,如果不存在则创建文件,等同于上面os.Create

f4, _ := os.OpenFile("./4.txt", os.O_RDWR|os.O_CREATE|os.O_TRUNC, 0666)
defer f4.Close()

用os.path.join()连接两个文件名地址的时候,就比如

os.path.join("D:\","test.txt")      \\结果是D:\test.txt

删除指定目录下所有文件

os.Remove("abc/d/e/f")

删除指定目录

os.RemoveAll("abc")

重命名文件

os.Rename("./2.txt", "./2_new.txt")

如有不对欢迎指正,相互学习,共同进步。

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐