检测文件是否存在

//存在返回 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())文件。

go语言文件系统的更多相关文章

  1. C++ ofstream和ifstream具体的方法和C语言file说明

    ofstream是从内存到硬盘,ifstream是从硬盘到内存,事实上所谓的流缓冲就是内存空间; 在C++中,有一个stream这个类,全部的I/O都以这个"流"类为基础的,包含我 ...

  2. Linux下安装Redmine(项目管理软件)

    前置条件需要安装 ruby,rubygems,rake,rails和mysql数据库. 安装Redmine 和 Ruby.Rails对应的版本: Redmine version Supported R ...

  3. golangHTML标签提取器soup

    什么是soup 类似python中beatifulsoup,用于提取html标签提取,多用于爬虫.它可以很好的处理不规范标记并生成剖析树(parse tree). 它提供简单又常用的导航,搜索以及修改 ...

  4. 运用Python语言编写获取Linux基本系统信息(二):文件系统使用情况获取

    本文跟着上一篇文章继续写,上一篇文章的链接 运用Python语言编写获取Linux基本系统信息(一):获得Linux版本.内核.当前时间 一.随便说说 获取文件系统使用情况的思路和上一篇获取主要系统是 ...

  5. C语言整理——文件系统和文件访问

    标准C中规定了文件系统的访问和对文件本身的访问.不管是windows系统或者是泛unix系统,都实现了这些接口.在了解这些知识后,跨平台编程也将非常容易. 对文件系统的访问接口有: chdrive() ...

  6. 【操作系统】C语言编写的FAT16文件系统

    [操作系统]C语言编写的FAT16文件系统 这是操作系统的期末课程设计作业之一,主要功能是在物理内存中虚拟出一个1M大小的FAT16的文件系统,然后把它读入内存中,进行具体的文件操作,具体的实用性不大 ...

  7. FastDFS是使用c语言编写的开源高性能分布式文件系统

    FastDFS是什么 FastDFS是使用c语言编写的开源高性能分布式文件系统 是由淘宝开发平台部资深架构师余庆开发,FastDFS孵化平台板块 他对文件进行管理,功能包括文件存储,文件同步,文件访问 ...

  8. 【程序员技术练级】学习一门脚本语言 python(二)遍历本地文件系统

    这篇将讲述怎么使用python来遍历本地文件系统,并把文件按文件大小从小到大排序的一个小例子 在这个例子中,主要会用到python内置的和OS模块的几个函数: os.walk() : 该方法用来遍历指 ...

  9. 操作系统: 二级文件夹文件系统的实现(c/c++语言)

    操作系统的一个课程设计,实现一个二级文件夹文件系统. 用disk.txt模拟磁盘,使用Help查看支持的命令及其操作方式,root为超级用户(写在disk.txt中) 文件的逻辑结构:流式文件. 物理 ...

随机推荐

  1. Mysql的登录

    一.mysql申请连接的四种方式 1 . TCP/IP TCP/IP套接字连接方式是MySQL在任何平台都提供的一种连接方式,也是网络中使用最多的一种方式.这种方式在TCP/IP连接上建立一个基于网络 ...

  2. Django报错:'Specifying a namespace in include() without providing an app_name '

    环境:win10(64)+pycharm2018.3+python3.7 在网页项目中使用include()方法 项目目录中同时存在app/urls.py和proj/urls.py 在proj/url ...

  3. Intouch 制作自定义登录弹窗

    在新的自动化项目中,因为业主对设计审美要求比较高,对Intouch自带脚本呼出登录窗体不满意,故而制作自定义登录弹窗来满足其审美需求.在寻求自控群前辈的经验下,将其整理成博客,供大家参考. 1.登录窗 ...

  4. Python小白的数学建模课-12.非线性规划

    非线性规划是指目标函数或约束条件中包含非线性函数的规划问题,实际就是非线性最优化问题. 从线性规划到非线性规划,不仅是数学方法的差异,更是解决问题的思想方法的转变. 非线性规划问题没有统一的通用方法, ...

  5. Android Jetpack 架构组件最佳实践之“网抑云”APP

    背景 近几年,Android 相关的新技术层出不穷.往往这个技术还没学完,下一个新技术又出来了.很多人都是一脸黑人问号? 不少开发者甚至开始哀嚎:"求求你们别再创造新技术了,我们学不动了!& ...

  6. MongoDB-01-基础

    mongodb逻辑结构 Mongodb 逻辑结构 MySQL逻辑结构 库 (database) 库 集合(collection) 表 文档(document) 数据行 安装部署 1 系统准备 1 这里 ...

  7. 线程队列 concurrent 协程 greenlet gevent

    死锁问题 所谓死锁:是指两个或两个以上的进程或线程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进 ...

  8. 从自旋锁、睡眠锁、读写锁到 Linux RCU 机制讲解

    ​    同步自我的 csdn 博客 6.S081 从自旋锁.睡眠锁.读写锁到 Linux RCU 机制讲解_我说我谁呢 --CSDN博客 总结一下 O/S 课程里面和锁相关的内容. 本文是 6.S0 ...

  9. python中的logging日志

    logging使用 import logging import os from logging import handlers from constants.constants import Cons ...

  10. flutter canvas圆圈转圈动画

    import 'dart:math'; import 'dart:ui'; import 'package:flutter/material.dart'; void main() => runA ...