文件操作
I 相关api介绍
建立File内存地址api
//返回File的内存地址,错误信息,通过os库调用
func Create(name string) (file *File, err Error)
//返回文件的内存地址,通过os库调用
func NewFile(fd int, name string) *File
打开文件api
//返回File的内存地址,错误信息,通过os库调用
func Open(name string)(file *File,err Error)
//返回File的内存地址,错误信息,通过os库调用
func OpenFile(name string,flag int,perm unit32)(file *File,err Error)
写文件api
//写入一个slice,返回写的个数,错误信息,通过File的内存地址调用
func (file *File)Write(b []byte)(n int,err Error)
//从slice的某个位置开始写入,返回写的个数,错误信息,通过File的内存地址调用
func (file *File)WriteAt(b []byte,off int64)(n int,err Error)
//写入一个字符串,返回写的个数,错误信息,通过File的内存地址调用
func (file *File) WriteString(s string)(ret int,err Error)
读文件api
//读取一个slice,返回读的个数,错误信息,通过File的内存地址调用
func (file *File) Read(b []byte)(n int, err Error)
//从slice的某个位置开始读取,返回读到的个数,错误信息,通过File的内存地址调用
func (file *File) ReadAt(b []byte,off int64)(n int,err Error)
删除文件api
//传入文件的路径来删除文件,返回错误个数
func Remove(name string) Error
II. 写文件的实例代码
package main
import (
"fmt"
"os"
)
func main() {
myFile := "/home/liudanbing/abc.txt"
fout, err := os.Create(myFile)
//fout, err := os.OpenFile(myFile, os.O_CREATE, 0644)
if err != nil {
fmt.Println(err)
return
}
for i := 0; i < 10; i++ {
outstr := fmt.Sprintf("%s:%d\n", "Hello world", i)
fout.WriteString(outstr)
fout.Write([]byte("abcd\n"))
}
fout.Close()
}
运行结果abc.txt中:
liudanbing@iZ25p2sxbu1Z:~/go_lession/file$ cat ~/abc.txt
Hello world:0
abcd
Hello world:1
abcd
Hello world:2
abcd
Hello world:3
abcd
Hello world:4
abcd
Hello world:5
abcd
Hello world:6
abcd
Hello world:7
abcd
Hello world:8
abcd
Hello world:9
abcd
III.读文件的实例代码
package main
import (
"fmt"
"os"
)
func test_read_file(filename string) {
fin, err := os.Open(filename)
if err != nil {
fmt.Println(err)
}
defer fin.Close()
buf := make([]byte, 1024) //开辟1024个字节的slice 作为缓冲
for {
n, _ := fin.Read(buf)
if n == 0 {
//0 表示到达EOF
break
}
os.Stdout.Write(buf)
}
}
func main() {
test_read_file("/home/liudanbing/abc.txt")
同时使用os.Open和os.Create操作文件
package main
import (
"io"
"os"
)
func main() {
fi, err := os.Open("/home/itcast/abc.txt")//打开输入*File
if err != nil { panic(err) }
defer fi.Close()
fo, err := os.Create("/home/itcast/abc_new.txt")//创建输出*File
if err != nil { panic(err) }
defer fo.Close()
buf := make([]byte, 1024)
for {
n, err := fi.Read(buf)//从input.txt读取
if err != nil && err != io.EOF { panic(err) }
if n == 0 { break }
if n2, err := fo.Write(buf[:n]); err != nil {//写入output.txt,直到错误
panic(err)
} else if n2 != n {
panic("error in writing")
}
}
}
用bufio库
package main
import (
"bufio"
"io"
"os"
)
func main() {
fi, err := os.Open("input.txt")//打开输入*File
if err != nil { panic(err) }
defer fi.Close()
r := bufio.NewReader(fi)//创建一个读取缓冲流
fo, err := os.Create("output.txt")//创建输出*File
if err != nil { panic(err) }
defer fo.Close()
w := bufio.NewWriter(fo)//创建输出缓冲流
buf := make([]byte, 1024)
for {
n, err := r.Read(buf)
if err != nil && err != io.EOF { panic(err) }
if n == 0 { break }
if n2, err := w.Write(buf[:n]); err != nil {
panic(err)
} else if n2 != n {
panic("error in writing")
}
}
if err = w.Flush(); err != nil { panic(err) }
}
使用ioutil库
package main
import (
"io/ioutil"
)
func main() {
b, err := ioutil.ReadFile("input.txt")//读文件
if err != nil { panic(err) }
err = ioutil.WriteFile("output.txt", b, 0644)//写文件
if err != nil { panic(err) }
}
遍历文件夹
package main
import (
"path/filepath"
"os"
"fmt"
"flag"
)
func getFilelist(path string) {
err := filepath.Walk(path, func(path string, f os.FileInfo, err error) error {
if ( f == nil ) {return err}
if f.IsDir() {return nil}
println(path)
return nil
})
if err != nil {
fmt.Printf("filepath.Walk() returned %v\n", err)
}
}
func main(){
flag.Parse()
root := flag.Arg(0)
getFilelist(root)
}