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
}
}
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成功")
}
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成功")
}