go 文件相关操作
前言
常见的文件操作:读、写、追加、复制,在go语言中标准库os提供了Openfile函数来进行此类操作,其原型如下:
func OpenFile(name string, flag int, perm FileMode) (file *File, err error)
其中 name 是文件的文件名,如果不是在当前路径下运行需要加上具体路径;flag 是文件的处理参数,为 int 类型,根据系统的不同具体值可能有所不同,但是作用是相同的;
perm 是文件的操作权限, 一般是0开头 后跟 权限777 , 同linux中的 文件权限一样, 1 为执行、 2为写、4为读。
flag参数
常用的 flag 文件处理参数:
- O_RDONLY:只读模式打开文件;
- O_WRONLY:只写模式打开文件;
- O_RDWR:读写模式打开文件;
- O_APPEND:写操作时将数据附加到文件尾部(追加);
- O_CREATE:如果不存在将创建一个新文件;
- O_EXCL:和 O_CREATE 配合使用,文件必须不存在,否则返回一个错误;
- O_SYNC:当进行一系列写操作时,每次都要等待上次的 I/O 操作完成再进行;
- O_TRUNC:如果可能,在打开时清空文件。
【示例 1】:创建一个新文件 golang.txt,并在其中写入 5 句“http://c.biancheng.net/golang/”。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | package main import ( "bufio" "fmt" "os" ) func main() { //创建一个新文件,写入内容 5 句 “http://c.biancheng.net/golang/” filePath := "e:/code/golang.txt" file, err := os.OpenFile(filePath, os.O_WRONLY|os.O_CREATE, 0666) if err != nil { fmt.Println( "文件打开失败" , err) } //及时关闭file句柄 defer file.Close() //写入文件时,使用带缓存的 *Writer write := bufio.NewWriter(file) for i := 0; i < 5; i++ { write.WriteString( "http://c.biancheng.net/golang/ \n" ) } //Flush将缓存的文件真正写入到文件中 write.Flush() } |
执行成功之后会在指定目录下生成一个 golang.txt 文件,打开该文件如下图所示:
【示例 2】:打开一个存在的文件,在原来的内容追加内容“C语言中文网”
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | package main import ( "bufio" "fmt" "os" ) func main() { filePath := "e:/code/golang.txt" file, err := os.OpenFile(filePath, os.O_WRONLY|os.O_APPEND, 0666) if err != nil { fmt.Println( "文件打开失败" , err) } //及时关闭file句柄 defer file.Close() //写入文件时,使用带缓存的 *Writer write := bufio.NewWriter(file) for i := 0; i < 5; i++ { write.WriteString( "C语言中文网 \r\n" ) } //Flush将缓存的文件真正写入到文件中 write.Flush() } |
执行成功之后,打开 golang.txt 文件发现内容追加成功,如下图所示:
【示例 3】:打开一个存在的文件,将原来的内容读出来,显示在终端,并且追加 5 句“Hello,C语言中文网”。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | package main import ( "bufio" "fmt" "io" "os" ) func main() { filePath := "e:/code/golang.txt" file, err := os.OpenFile(filePath, os.O_RDWR|os.O_APPEND, 0666) if err != nil { fmt.Println( "文件打开失败" , err) } //及时关闭file句柄 defer file.Close() //读原来文件的内容,并且显示在终端 reader := bufio.NewReader(file) for { str, err := reader.ReadString( '\n' ) if err == io.EOF { break } fmt.Print(str) } //写入文件时,使用带缓存的 *Writer write := bufio.NewWriter(file) for i := 0; i < 5; i++ { write.WriteString( "Hello,C语言中文网。 \r\n" ) } //Flush将缓存的文件真正写入到文件中 write.Flush() } |
执行成功之后,会在控制台打印出文件的内容,并在文件中追加指定的内容,如下图所示:
【示例 4】:编写一个程序,将一个文件的内容复制到另外一个文件(注:这两个文件都已存在)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | package main import ( "fmt" "io/ioutil" ) func main() { file1Path := "e:/code/golang.txt" file2Path := "e:/code/other.txt" data, err := ioutil.ReadFile(file1Path) if err != nil { fmt.Printf( "文件打开失败=%v\n" , err) return } err = ioutil.WriteFile(file2Path, data, 0666) if err != nil { fmt.Printf( "文件打开失败=%v\n" , err) } } |
执行成功后,发现内容已经复制成功,如下图所示:
参考:http://c.biancheng.net/view/5729.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具