go 官方库的文件操做分散在多个包中,感受有点乱,好比os
,ioutil
包,基于别人总结的基础上简单总结一下
package main import ( "os" "log" ) var ( newFile *os.File err error ) func main(){ //建立文件 newFile,err=os.Create("text.txt") checkErr(err) log.Println(newFile) newFile.Close() } /** 检查错误 */ func checkErr(err error){ if err!=nil{ log.Fatal(err) } }
package main import ( "log" "os" ) func main(){ // 裁剪一个文件到100个字节。 // 若是文件原本就少于100个字节,则文件中原始内容得以保留,剩余的字节以null字节填充。 // 若是文件原本超过100个字节,则超过的字节会被抛弃。 // 这样咱们老是获得精确的100个字节的文件。 // 传入0则会清空文件。 err:=os.Truncate("text.txt",100) checkErr(err) } func checkErr(err error){ if err!=nil{ log.Panic(err) } }
package main import ( "log" "os" "fmt" ) var ( fileInfo os.FileInfo err error ) func main() { fileInfo, err = os.Stat("text.txt") checkErr(err) fmt.Println("FIle name:", fileInfo.Name()) fmt.Println("Size in bytes:", fileInfo.Size()) fmt.Println("Permissions:", fileInfo.Mode()) fmt.Println("Last modified:", fileInfo.ModTime()) fmt.Println("Is directory:", fileInfo.IsDir()) fmt.Printf("System interface type:%T\n", fileInfo.Sys()) fmt.Printf("System info:%+v\n\n", fileInfo.Sys()) } func checkErr(err error) { if err != nil { log.Panic(err) } }
运行结果node
rename
和move
原理同样
package main import ( "log" "os" ) func main() { oldPath, newPath := "text.txt", "test.txt" err := os.Rename(oldPath, newPath) checkErr(err) } func checkErr(err error) { if err != nil { log.Panic(err) } }
package main import ( "log" "os" ) func main() { err := os.Remove("text.txt") checkErr(err) } func checkErr(err error) { if err != nil { log.Panic(err) } }
package main import ( "log" "os" ) func main() { // 简单地以只读的方式打开。下面的例子会介绍读写的例子。 file,err:=os.Open("test.txt") checkErr(err) file.Close() // OpenFile提供更多的选项。 // 最后一个参数是权限模式permission mode // 第二个是打开时的属性 file1,err:=os.OpenFile("hello.txt",os.O_CREATE|os.O_APPEND,0666) checkErr(err) file1.Close() //下面的属性能够单独使用,也能够组合使用。 // 组合使用时可使用 OR 操做设置 OpenFile的第二个参数,例如: // os.O_CREATE|os.O_APPEND // 或者 os.O_CREATE|os.O_TRUNC|os.O_WRONLY // os.O_RDONLY // 只读 // os.O_WRONLY // 只写 // os.O_RDWR // 读写 // os.O_APPEND // 往文件中添建(Append) // os.O_CREATE // 若是文件不存在则先建立 // os.O_TRUNC // 文件打开时裁剪文件 // os.O_EXCL // 和O_CREATE一块儿使用,文件不能存在 // os.O_SYNC // 以同步I/O的方式打开 } func checkErr(err error) { if err != nil { log.Panic(err) } }
package main import ( "log" "os" ) func main() { fileInfo,err:=os.Stat("hello.txt") if err!=nil{ if os.IsNotExist(err){ log.Fatalln("file does not exist") } } log.Println("file does exist. file information:") log.Println(fileInfo) }
package main import ( "os" "log" ) func main() { // 这个例子测试写权限,若是没有写权限则返回error。 // 注意文件不存在也会返回error,须要检查error的信息来获取究竟是哪一个错误致使。 file, err := os.OpenFile("1.txt", os.O_WRONLY, 0666) if err != nil { if os.IsPermission(err) { log.Println("Error write permission denied") } if os.IsNotExist(err) { log.Println("file does not exist") } } file.Close() // 测试读权限 file, err = os.OpenFile("test.txt", os.O_RDONLY, 0666) if err != nil { if os.IsPermission(err) { log.Println("Error:Read permission denied") } } file.Close() }
package main import ( "os" "log" "time" "fmt" ) func main(){ // 使用Linux风格改变文件权限 err:=os.Chmod("test.txt",0777) checkErr(err) // 改变文件全部者 err=os.Chown("test.txt",os.Geteuid(),os.Getgid()) checkErr(err) twoDaysFromNow:=time.Now().Add(48*time.Hour) lastAccessTime:=twoDaysFromNow lastModifyTime:=twoDaysFromNow err=os.Chtimes("test.txt",lastAccessTime,lastModifyTime) checkErr(err) fileInfo,err:=os.Stat("test.txt") fmt.Println("file modified time:",fileInfo.ModTime()) } func checkErr(err error){ if err!=nil{ log.Println(err) } }
一个普通的文件是一个指向硬盘的inode的地方。
硬连接建立一个新的指针指向同一个地方。只有全部的连接被删除后文件才会被删除。硬连接只在相同的文件系统中才工做。你能够认为一个硬连接是一个正常的连接。symbolic link,又叫软链接,和硬连接有点不同,它不直接指向硬盘中的相同的地方,而是经过名字引用其它文件。他们能够指向不一样的文件系统中的不一样文件。并非全部的操做系统都支持软连接。测试
package main import ( "os" "log" "fmt" ) func main() { // 建立一个硬连接。 // 建立后同一个文件内容会有两个文件名,改变一个文件的内容会影响另外一个。 // 删除和重命名不会影响另外一个。 err := os.Link("original.txt", "original_also.txt") if err != nil { log.Fatal(err) } fmt.Println("creating sym") // Create a symlink err = os.Symlink("original.txt", "original_sym.txt") if err != nil { log.Fatal(err) } // Lstat返回一个文件的信息,可是当文件是一个软连接时,它返回软连接的信息,而不是引用的文件的信息。 // Symlink在Windows中不工做。 fileInfo, err := os.Lstat("original_sym.txt") if err != nil { log.Fatal(err) } fmt.Printf("Link info: %+v", fileInfo) //改变软连接的拥有者不会影响原始文件。 err = os.Lchown("original_sym.txt", os.Getuid(), os.Getgid()) if err != nil { log.Fatal(err) } }