最可靠方式是用 os.Stat 配合 os.IsNotExist 判断:调用 os.Stat(path) 后,若 !os.IsNotExist(err) 为真则文件存在;它返回元数据且语义明确,优于 os.Open 或错误字符串比较。
在 Go 语言中,检测文件是否存在最常用、最可靠的方式是使用 os.Stat,而不是直接用 os.IsNotExist 包装错误来判断——因为 os.Stat 不仅能告诉你文件存不存在,还能返回文件的详细状态信息,且语义清晰、行为确定。
os.Stat 尝试获取指定路径的文件系统信息。如果路径存在且可访问,它返回一个 os.FileInfo;否则返回一个非 nil 的 error。关键点在于:**不能只看 error 是否为 nil,而要检查 error 是否由“文件不存在”引起**。
os.Stat(path)
os.IsNotExist(err) 判断是否真的“不存在”下面是一个安全、通用的判断函数:
func fileExists(path string) bool {
_, err := os.Stat(path)
return !os.IsNotExist(err)
}注意:
- 不要用 err == nil 作为“存在”的唯一依据(虽然多数情况成立),但更推荐用 !os.IsNotExist(err) 明确表达意图。
- 返
回 true 并不意味着你一定能读/写该文件,只是说明路径在文件系统中存在且 Stat 调用成功。
err.Error() == "no such file",平台依赖、不可靠fi.Mode().IsRegular()
os.Stat 会返回 os.IsNotExist 错误;要用 os.Lstat 检查链接本身是否存在如果不仅要存在,还要确保是常规文件(而非目录、设备文件等),可以这样写:
func isRegularFile(path string) bool {
fi, err := os.Stat(path)
if os.IsNotExist(err) {
return false
}
if err != nil {
return false // 其他错误,如 permission denied
}
return fi.Mode().IsRegular()
}这个函数比单纯“存在”更严格,适合读取配置、日志等场景。