Go中删除文件用os.Remove(单文件或空目录),非空目录须用os.RemoveAll;需检查错误类型如os.ErrNotExist,并用os.Stat预判路径类型以避免误删,注意跨平台差异。

在 Go 中删除文件很简单,主要用 os.Remove 函数,它适用于单个文件或空目录;若需递归删除非空目录,则用 os.RemoveAll。
删除单个文件
使用 os.Remove 可安全删除一个已存在的文件。如果文件不存在,会返回 os.ErrNotExist 错误,建议检查错误类型再做处理。
- 调用
os.Remove("path/to/file.txt") - 检查错误:若
err != nil,可用errors.Is(err, os.ErrNotExist)判断是否因文件不存在而失败 - 注意:不能用
Remove删除非空目录,否则返回os.ErrInvalid(Windows)或ENOTEMPTY(Unix)
递归删除整个目录(含内容)
当需要彻底清空一个目录及其所有子文件、子目录时,用 os.RemoveAll。它会自动跳过只读文件(部分系统下可能失败),并尽量清理所有内容。
- 调用
os.RemoveAll("path/to/dir") - 成功时返回
nil;失败时错误类型可能是权限不足、路径正在被占用等 - 适合清理临时目录、测试输出、缓存文件夹等场景
安全删除前的常见检查
避免误删,建议在调用删除函数前加一层判断:
立即学习“go语言免费学习笔记(深入)”;
- 用
os.Stat检查路径是否存在且是文件/目录:fi, err := os.Stat(path) - 用
fi.IsDir()区分类型,防止对目录误用Remove - 可选:校验路径是否在允许范围内(如禁止删除根目录、用户主目录等)
跨平台注意事项
Go 的文件操作基本跨平台兼容,但仍有细节要注意:
- Windows 下删除正在被其他进程打开的文件会失败(提示“Access is denied”)
- Linux/macOS 下,若目录非空却调用
Remove,会报ENOTEMPTY,此时应改用RemoveAll - 路径分隔符统一用
/或filepath.Join构造,Go 会自动适配系统
基本上就这些。核心就是分清 Remove 和 RemoveAll 的适用场景,配合错误判断和路径检查,就能稳妥完成文件删除操作。










