检测文件是否存在

//存在返回 true,不存在返回 false
func fileIfExist(filename string) bool {
_, err := os.Stat(filename)
if nil != err {
fmt.Println(filename, "is not exist!")
return false
} if os.IsNotExist(err) {
return false
} return true
}

打开文件

f, err := os.Open(filename)
if nil != err {
fmt.Println("open", filename, "failed!")
return
}
defer f.Close()

如果文件不存在,就会返回错误,如果存在就以只读的方式打开文件。

还可以使用 os.OpenFile() 打开文件,达到不存在就新建,存在就清空(os.O_TRUNC)的目的。当然,也可以不清空文件(os.O_APPEND)。

f, err := os.OpenFile(filename, os.O_RDWR | os.O_CREATE | os.O_TRUNC, 0666)
if nil != err {
fmt.Println("create", filename, "failed!")
return
}
defer f.Close()

新建文件

f, err := os.Create(filename)
if nil != err {
fmt.Println("create", filename, "failed!")
return
}
defer f.Close()

注意:如果文件已经存在,那么 os.Create() 会将文件清空。可以使用 os.OpenFile() 新建文件, 参数 flagos.O_CREATE | os.O_EXCL。如果文件已经存在,那么该函数就会返回错误。

f, err := os.OpenFile(filename, os.O_CREATE | os.O_EXCL, 0666)
if nil != err {
fmt.Println("create", filename, "failed!")
return
}
defer f.Close()

读取文件

读取全部内容

content := make([]byte, 1024)   //需要预先分配空间
f, _ := os.Open(filename)
defer f.Close()
_, err := f.Read(content)
if nil != err {
fmt.Println("read", filename, "failed!")
return
}

读取文件内容可以使用 File 的方法——Read。但是使用该方法时需要预先分配空间,用于存储读取的文件内容。我们当然可以提前获取文件的大小,但是这种方式仍然不如 ioutil.ReadAll() 方便。甚至可以直接使用 ioutil.ReadFile()

ioutil.ReadAll()

f, _ := os.Open(filename)
defer f.Close()
content, err := ioutil.ReadAll(f)
if nil != err {
fmt.Println("read", filename, "failed!")
return
}
fmt.Println(string(content))

ioutil.ReadFile()

content, err := ioutil.ReadFile(filename)
if nil != err {
fmt.Println("read", filename, "failed!")
return
}
fmt.Println(string(content))

按行读取

f, _ := os.Open(filename)
defer f.Close()
scanner := bufio.NewScanner(f) //按行读取
for scanner.Scan() {
fmt.Println(scanner.Text()) //输出文件内容
}

写入文件

f, _ := os.OpenFile(filename, os.O_WRONLY | os.O_APPEND, 0666)
defer f.Close()
_, err = f.WriteString("target_compile_option")
if nil != err {
fmt.Println(err)
}

这里使用 os.OpenFile() 以追加的方式打开文件。为什么不使用 os.Open() 打开文件呢?因为 os.Open() 是以只读的方式打开文件,无法向文件写入数据。

我们也可以使用 ioutil.WriteFile() 写文件。

writeContent := "write file test"
err = ioutil.WriteFile(filename, []byte(writeContent), os.ModePerm)
if nil != err {
fmt.Println("write", filename, "failed!")
}

注意:使用 ioutil.WriteFile(filename string, data []byte, perm os.FileMode) 向文件中写入时,如果文件存在,文件会先被清空,然后再写入。如果文件不存在,就会以 perm 权限先创建文件,然后再写入。

关闭文件

直接调用 FileClose() 方法。

f, _ := os.Open(filename)
f.Close()

最好使用 defer 关键字执行 Close() 方法,这样能够保证函数退出时文件能被关闭。

删除文件

err := os.Remove(filename)

删除文件前确保文件没有被其他程序使用。如果在当前程序中该文件已被打开,需要先关闭(Close())文件。

最新文章

  1. SQL: ROW_NUMBER
  2. .NET微信通过授权获取用户的基本信息
  3. POJ 1035问题解答
  4. LINUX下mysql的大小写是否区分设置 转
  5. 【HDOJ】2389 Rain on your Parade
  6. c# 动态产生控件 注册动态控件事件
  7. CacheConcurrencyStrategy五种缓存方式
  8. Servlet生命周期和注解配置
  9. inotify事件监控工具
  10. 《Linux内核分析》第三周:Linux系统启动过程
  11. electron demo项目npm install安装失败解决办法
  12. 什么是Github?
  13. 【字符串哈希】The 16th UESTC Programming Contest Preliminary F - Zero One Problem
  14. Java JarFile 解析
  15. Linux 编译内核
  16. 在WINDOWS下安装PEAR
  17. 3 破解密码,xshell连接
  18. HDU 3389 Game (阶梯博弈)
  19. Linux文件查找命令
  20. 01-python进阶-拾遗

热门文章

  1. Pelles C 五光十色中的一抹经典
  2. SpringCloud升级之路2020.0.x版-3.Eureka Server 与 API 网关要考虑的问题
  3. Spring WebFlux 基础教程:参数校验
  4. 解决:无法从 Windows 应用商店下载。请检查网络连接
  5. vue的table切换
  6. OpenCV 之 特征匹配
  7. TextLineCodecFactory笔记
  8. Notes about BSD
  9. 快速从SQL语法过度到Elasticsearch的DSL语法
  10. Java调用Zookeeper