欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Go语言编程中判断文件是否存在是创建目录的方法

程序员文章站 2022-04-29 13:03:05
判断文件是否存在 os.isexists()函数和os.isnotexists(),他们的函数的原形是func isexist(err error) bool func...

判断文件是否存在
os.isexists()函数和os.isnotexists(),他们的函数的原形是func isexist(err error) bool func isnotexist(err error) bool 都是传入一个err返回bool 这里注意了 err已经定义好了

复制代码 代码如下:

  /*
 var (
     errinvalid    = errors.new("invalid argument")
     errpermission = errors.new("permission denied")
     errexist      = errors.new("file already exists")
     errnotexist   = errors.new("file does not exist")
 )
*/

这里我们看到了errors这个包,那我们讲一下这个包,这个包就一个方法就是errors.new()函数原形是func new(text string) error实例代码
复制代码 代码如下:

import (
 "errors"
 "fmt"
)

func main() {
 //这里就一个方法func new(text string) error 我们可以自己定义
 err := errors.new("widuu blog only golang")
 if err != nil {
  fmt.println(err) //这里就是输出了我们自己定义的错误信息 //widuu blog only golang
 }
}


下面通过实例代码讲解一下
复制代码 代码如下:

  import (
 "fmt"
 "os"
)

func main() {
 _, err := os.open("widuu.go")
 if err != nil {
  fmt.println(os.isnotexist(err)) //true  证明文件已经存在
  fmt.println(err)                //open widuu.go: no such file or directory
 }

 //这个时候你可以这样判断文件是否存在

 f, err := os.open("widuu.go")
 if err != nil && os.isnotexist(err) {
  fmt.println(f, "文件不存在") //为什么打印nil 是这样的如果file不存在 返回f文件的指针是nil的 所以我们不能使用defer f.close()会报错的
 }

//我们弄出一个文件已经存在的错误来实验os.isexists() 如下是os定义的常量
 /*
  var (
      errinvalid    = errors.new("invalid argument")
      errpermission = errors.new("permission denied")
      errexist      = errors.new("file already exists")
      errnotexist   = errors.new("file does not exist")
  )
 */
 fmt.println(os.isexist(os.errexist)) //这里就会输出true
 //我们后边马上提到link
 err = os.link("osexists.go", "1.go")
 if err != nil {
  fmt.println(os.isexist(err))  //因为我1.go这个文件存在了 所以说返回true
 }
}


创建目录
os.mkdir创建单个目录函数原形func mkdir(name string, perm filemode) error输入一个目录的名称和目录的权限,我们可以用默认的os.modeperm然后返回的是一个error的信息,我们看下,也一块复习前边的一点知识

复制代码 代码如下:

 import (
 "fmt"
 "os"
)

func main() {
 var path string
 if os.ispathseparator('\\') {  //前边的判断是否是系统的分隔符
  path = "\\"
 } else {
  path = "/"
 }
 fmt.println(path)
 dir, _ := os.getwd()  //当前的目录
 err := os.mkdir(dir+path+"md", os.modeperm)  //在当前目录下生成md目录
 if err != nil {
  fmt.println(err)
 }
 fmt.println("创建目录" + dir + path + "md成功")
}


os.mkdirall()函数原形是func mkdirall(path string, perm filemode) error输入的是多级目录结构和权限返回的是error的信息
复制代码 代码如下:

import (
 "fmt"
 "os"
)

func main() {
 dir, _ := os.getwd()
 err := os.mkdirall(dir+"/a/b/c", os.modeperm)  //生成多级目录
 if err != nil {
  fmt.println(err)
 }
 fmt.println("创建文件夹" + dir + "/a/b/c成功")
}