答案:Golang文件操作依赖os和io包,通过os.File、io.Reader、io.Writer及os包函数实现文件创建、读写、目录遍历;使用os.Create创建文件,file.Write或WriteString写入数据,os.Open结合file.Read读取内容,filepath.Walk遍历目录;大文件读取推荐bufio.NewReader逐行处理;错误需逐层检查并用defer关闭文件;文件是否存在可通过os.Stat和os.IsNotExist判断。

Golang文件操作的核心在于
os
io
Golang的文件操作围绕着几个核心概念:
os.File
io.Reader
io.Writer
os
Create
Open
Mkdir
1. 创建文件:
package main
import (
"fmt"
"os"
)
func main() {
file, err := os.Create("example.txt")
if err != nil {
fmt.Println("创建文件失败:", err)
return
}
defer file.Close() // 确保文件在使用完毕后关闭
fmt.Println("文件创建成功!")
}这段代码尝试创建一个名为
example.txt
defer file.Close()
立即学习“go语言免费学习笔记(深入)”;
2. 写入文件:
package main
import (
"fmt"
"os"
)
func main() {
file, err := os.Create("example.txt")
if err != nil {
fmt.Println("创建文件失败:", err)
return
}
defer file.Close()
data := []byte("Hello, Golang file operation!\n")
n, err := file.Write(data)
if err != nil {
fmt.Println("写入文件失败:", err)
return
}
fmt.Printf("成功写入 %d 字节\n", n)
// 也可以使用WriteString
n, err = file.WriteString("Another line of text.\n")
if err != nil {
fmt.Println("WriteString 失败:", err)
return
}
fmt.Printf("成功写入 %d 字节 (WriteString)\n", n)
}这里,我们向
example.txt
file.Write
file.WriteString
3. 读取文件:
package main
import (
"fmt"
"io"
"os"
)
func main() {
file, err := os.Open("example.txt")
if err != nil {
fmt.Println("打开文件失败:", err)
return
}
defer file.Close()
buffer := make([]byte, 1024) // 创建一个缓冲区
n, err := file.Read(buffer)
if err != nil && err != io.EOF { // io.EOF 表示文件结束
fmt.Println("读取文件失败:", err)
return
}
fmt.Printf("读取了 %d 字节\n", n)
fmt.Println(string(buffer[:n])) // 将读取到的字节转换为字符串并打印
}这段代码打开
example.txt
buffer
file.Read
io.EOF
4. 目录遍历:
package main
import (
"fmt"
"os"
"path/filepath"
)
func main() {
root := "." // 从当前目录开始
err := filepath.Walk(root, func(path string, info os.FileInfo, err error) error {
if err != nil {
fmt.Println("访问出错:", err)
return err
}
fmt.Println(path)
return nil
})
if err != nil {
fmt.Println("遍历目录失败:", err)
}
}filepath.Walk
os.FileInfo
对于大文件,一次性读取到内存中是不现实的。更高效的做法是使用
bufio.NewReader
package main
import (
"bufio"
"fmt"
"os"
)
func main() {
file, err := os.Open("large_file.txt")
if err != nil {
fmt.Println("打开文件失败:", err)
return
}
defer file.Close()
reader := bufio.NewReader(file)
for {
line, err := reader.ReadString('\n')
if err != nil {
if err != io.EOF {
fmt.Println("读取行失败:", err)
}
break // 文件结束或发生错误
}
fmt.Println(line)
}
}这种方式可以避免一次性加载整个文件到内存,从而提高效率。
文件操作中,错误处理至关重要。你需要检查每个可能出错的步骤,并采取适当的措施。这通常包括:
os.Create
os.Open
file.Write
file.Read
defer file.Close()
一个更健壮的错误处理示例:
package main
import (
"fmt"
"os"
)
func writeFile(filename string, data []byte) error {
file, err := os.Create(filename)
if err != nil {
return fmt.Errorf("创建文件失败: %w", err) // 使用 %w 包裹原始错误
}
defer func() {
if closeErr := file.Close(); closeErr != nil {
fmt.Println("关闭文件失败:", closeErr) // 记录关闭错误,但不影响主流程
}
}()
_, err = file.Write(data)
if err != nil {
return fmt.Errorf("写入文件失败: %w", err)
}
return nil
}
func main() {
err := writeFile("output.txt", []byte("This is some data.\n"))
if err != nil {
fmt.Println("发生错误:", err)
} else {
fmt.Println("文件写入成功!")
}
}这个示例使用了
fmt.Errorf
%w
os.Stat
os.Stat
os.ErrNotExist
package main
import (
"fmt"
"os"
)
func main() {
_, err := os.Stat("myfile.txt")
if err != nil {
if os.IsNotExist(err) {
fmt.Println("文件不存在")
} else {
fmt.Println("发生错误:", err)
}
} else {
fmt.Println("文件存在")
}
}os.IsNotExist
os.ErrNotExist
以上就是Golang文件操作怎么做 读写文件与目录遍历的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号