使用Go语言实现文件复制的完整流程

本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中, 这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例介绍的非常详细,需要的朋友可以参考下。

案例说明

我们将通过标准库 os 和 io 提供的函数:

  • 读取用户输入的源文件路径和目标文件路径;
  • 打开源文件;
  • 创建目标文件;
  • 使用 io.Copy 将源文件内容复制到目标文件中;
  • 正确处理错误并关闭文件。

涉及知识点

  • os.Open():打开已有文件(只读)
  • os.Create():创建或清空目标文件
  • defer:延迟关闭文件资源,防止泄漏
  • io.Copy():高效完成内容复制
  • 错误处理:判断 err != nil 保证程序健壮

示例代码

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
复制成功!

如果源文件不存在:

请输入源文件名:notfound.txt
请输入目标文件名:copy.txt
复制失败:open notfound.txt: no such file or directory

练习扩展

  1. 在复制前检查目标文件是否已存在,防止误覆盖(os.Stat 判断)
  2. 改为使用命令行参数传入文件名,而非交互输入(os.Args)
  3. 为大文件增加复制进度百分比(结合 bufio 和 Seek)
  4. 支持批量复制多个文件(for 遍历多个路径)
  5. 将复制日志写入日志文件(结合 log 包)

小结

这个案例展示了使用 Go 实现文件复制的完整流程,是掌握文件读写操作的关键案例之一。 通过合理的错误处理和标准库的组合,你可以快速实现功能强大又可靠的文件工具程序。

到此这篇关于使用Go实现文件复制的完整流程的文章就介绍到这了,更多相关Go文件复制内容请继续浏览下面的相关文章!