本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中。 这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等。
🛠 案例说明
我们将通过标准库 os
和 io
提供的函数:
- 读取用户输入的源文件路径和目标文件路径;
- 打开源文件;
- 创建目标文件;
- 使用
io.Copy
将源文件内容复制到目标文件中; - 正确处理错误并关闭文件。
🔑 涉及知识点
os.Open()
:打开已有文件(只读)os.Create()
:创建或清空目标文件defer
:延迟关闭文件资源,防止泄漏io.Copy()
:高效完成内容复制- 错误处理:判断
err != nil
保证程序健壮
✅ 示例代码
go
package main
import (
"fmt"
"io"
"os"
)
func main() {
var source string
var target string
fmt.Print("请输入源文件名:")
fmt.Scanln(&source)
fmt.Print("请输入目标文件名:")
fmt.Scanln(&target)
err := copyFile(source, target)
if err != nil {
fmt.Println("复制失败:", err)
} else {
fmt.Println("复制成功!")
}
}
// copyFile 将 src 文件复制到 dst 文件
func copyFile(src string, dst string) error {
// 打开源文件
srcFile, err := os.Open(src)
if err != nil {
return err
}
defer srcFile.Close()
// 创建目标文件(如果已存在会被清空)
dstFile, err := os.Create(dst)
if err != nil {
return err
}
defer dstFile.Close()
// 执行复制操作
_, err = io.Copy(dstFile, srcFile)
return err
}
📎 代码解析
行号 | 说明 |
---|---|
1-3 | 引入 fmt 、io 、os 标准库,用于输入输出和文件操作 |
5-10 | 提示用户输入两个文件路径(源文件和目标文件) |
12 | 调用 copyFile 函数执行复制,处理返回的错误 |
16-30 | copyFile 函数封装了完整的打开、创建和复制逻辑 |
22-23 | 使用 defer 确保无论复制是否成功,文件都能正确关闭 |
28 | io.Copy 是高效的文件复制函数,自动处理缓冲和流读取 |
🧪 示例运行
请输入源文件名:hello.txt
请输入目标文件名:hello_copy.txt
复制成功!
如果源文件不存在:
perl
请输入源文件名:notfound.txt
请输入目标文件名:copy.txt
复制失败:open notfound.txt: no such file or directory
💡 练习扩展
- 在复制前检查目标文件是否已存在,防止误覆盖(
os.Stat
判断) - 改为使用命令行参数传入文件名,而非交互输入(
os.Args
) - 为大文件增加复制进度百分比(结合
bufio
和Seek
) - 支持批量复制多个文件(
for
遍历多个路径) - 将复制日志写入日志文件(结合
log
包)
🧠 小结
这个案例展示了使用 Go 实现文件复制的完整流程,是掌握文件读写操作的关键案例之一。 通过合理的错误处理和标准库的组合,你可以快速实现功能强大又可靠的文件工具程序。