Go语言 碎片整理之 文件操作

文件是什么?
计算机中的文件是存储在外部介质(通常是磁盘)上的数据集合,文件分为文本文件和二进制文件。

打开和关闭文件

os.Open()函数能够打开一个文件,返回一个*File和一个error。对得到的文件实例调用close()方法能够关闭文件。

func main(){
    file,err := os.Open("./main.go")
    if err != nil{
        fmt.Println("open file failed!,err",err)
        return
    }
    fmt.Println("cool!")
    file.Close()
}

为了防止文件忘记关闭,我们通常使用defer注册文件关闭语句。

读取文件

file.Read()

基本使用

Read的方法定义如下:
func(f *File) Read(b []byte)(n int, err error)
它接收一个字节切片,返回读取的字节数和可能的具体错误,读到文件末尾时会返回0和io.EOF。

package main
import (
    "fmt"
    "os"
    "io"
)
func main(){
    file,err := os.Open("./main.go")
    if err != nil{
        fmt.Println("open file failed!,err", err)
        return
    }
    defer file.Close()
    var tmp = make([]byte,128)
    n, err := file.Read(tmp)
    if err == io.EOF {
        fmt.Println("文件读完了")
        return
    }
    if err != nil{
        fmt.Println("read file failed,err",err)
        return
    }
    fmt.Printf("读取了%d的字节数据\n",n)
    fmt.Println(string(tmp[:n]))
}

循环读取

使用for循环读取文件中的所有数据。

package main
import (
    "fmt"
    "os"
    "io"
)
func main(){
    file, err := os.Open("./main.go")
    if err != nil {
        fmt.Println("open file failed!, err", err)
        return
    }
    defer file.Close()
    var content []byte
    var tmp = make([]byte,128)
    for {
        n ,err := file.Read(tmp)
        if err == io.EOF{
            fmt.Println("文件读完了")
            break
        }
        if err != nil{
            fmt.Println("read file failed,err",err)
            return
        }
        content = append(content,tmp[:n]...)

    }
    fmt.Println(string(content))
}

bufio读取文件

bufio是在file的基础上封装了一层API,支持更多的功能。

package main
import (
    "fmt"
    "os"
    "io"
    "bufio"
)
func main(){
    file , err := os.Open("./main.go")
    if err != nil{
        fmt.Println("open file failed,err",err)
        return
    }
    defer file.Close()
    reader := bufio.NewReader(file)
    for {
        line, err := reader.ReadString(‘\n‘)
        if err == io.EOF{
            fmt.Println("文件读完了")
            break
        }
        if err != nil{
            fmt.Println("read file failed!,err",err)
            return
        }
        fmt.Println(line)
    }
}

使用ioutil读取整个文件

io/ioutil包的ReadFile方法能够读取完整的文件,只需要将文件名作为参数传入。

package main
import (
    "fmt"
    "io/ioutil"
)
func main(){
    content, err := ioutil.ReadFile("./main.go")
    if err != nil{
        fmt.Println("read file failed,err:",err)
        return 

    }
    fmt.Println(string(content))
}

文件写入操作

os.OpenFile()函数能够以指定的模式打开文件,从而实现文件写入相关功能。

func OpenFile(name string, flag int, perm FileMode) (*File, error){
    ....
}

其中:
name 是指要打开的文件名,flag是指打开文件的模式,模式有以下几种:


perm 文件权限,一个八进制数。r(读)04 ,w(写)02,x(执行)01。

Write和WriteString

func main() {
    file, err := os.OpenFile("xx.txt", os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0666)
    if err != nil {
        fmt.Println("open file failed, err:", err)
        return
    }
    defer file.Close()
    str := "hello 沙河"
    file.Write([]byte(str))       //写入字节切片数据
    file.WriteString("hello 小王子") //直接写入字符串数据
}

bufio.NewWriter

import (
    "io"
        "fmt"
)
func main() {
    file, err := os.OpenFile("xx.txt", os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0666)
    if err != nil {
        fmt.Println("open file failed, err:", err)
        return
    }
    defer file.Close()
    writer := bufio.NewWriter(file)
    for i := 0; i < 10; i++ {
        writer.WriteString("hello沙河\n") //将数据先写入缓存
    }
    writer.Flush() //将缓存中的内容写入文件
}

ioutil.WriteFile

func main() {
    str := "hello 沙河"
    err := ioutil.WriteFile("./xx.txt", []byte(str), 0666)
    if err != nil {
        fmt.Println("write file failed, err:", err)
        return
    }
}

练习

copyFile

func CopyFile(dstName, srcName string)(written int64,err error){
    src,err := os.Open(srcName)
    if err != nil{
        fmt.Printf("open %s failed,err: %v.\n", srcName,err)
        return
    }
    defer src.Close()
    dst ,err := os.OpenFile(dstName,os.O_CREATE|os.O_WRONLY,0644)
    if err != nil{
        fmt.Printf("open %s failed,err:%v.\n",dstName,err)
        return
    }
    defer dst.Close()
    return io.Copy(dst,src)
}
func main(){
    _,err := CopyFile("dst.txt","src.txt")
    if err != nil{
        fmt.Println("copy file failed,err",err)
        return
    }
    fmt.Println("Copy done!")
}

原文地址:https://blog.51cto.com/13766835/2404547

时间: 2024-08-05 17:24:01

Go语言 碎片整理之 文件操作的相关文章

【Go语言】集合与文件操作

本文目录 1.数据集合的主要操作 1_1.字典的声明 1_2.字典的初始化和创建 1_3.字典的访问和操作 1_4.其他类型的数据集 2.文件操作 2_1.文件操作概述os包和path包 2_2.文件操作示例 目录操作: 打开与建立文件: 写文件 : 读文件: 删除文件: 回到顶部 1.集合以及主要操作 首先要提到的是Go语言的内置数据类型map(字典类型 类似于Java中的HashMap和Swift中的Directory),这样你无需导入任何包便可 使用map类型了.map是一种特殊的数据结构

MySQL关于表碎片整理OPTIMIZE TABLE操作

MySQL关于表碎片整理OPTIMIZE TABLE操作的官方建议1.MySQL官方建议不要经常(每小时或每天)进行碎片整理,一般根据实际情况,只需要每周或者每月整理一次即可,可以写成定时任务来做.2.OPTIMIZE TABLE只对MyISAM,BDB和InnoDB表起作用,尤其是MyISAM表的作用最为明显.此外,并不是所有表都需要进行碎片整理,一般只需要对包含上述可变长度的文本数据类型的表进行整理即可.3.在OPTIMIZE TABLE运行过程中,MySQL会锁定表.4.默认情况下,直接对

归纳整理Linux下C语言常用的库函数----文件操作

在没有IDE的时候,记住一些常用的库函数的函数名.参数.基本用法及注意事项是很有必要的. 参照Linux_C_HS.chm的目录,我大致将常用的函数分为一下几类: 1. 内存及字符串控制及操作 2. 字符串转换 3. 字符测试 4. 文件操作 5. 时间日期 6. 常用数学函数 7. 文件内容操作 8. 文件权限控制 9. 进程操作 10. 线程操作 11. Socket操作 12. 信号处理 13. 数据结构及算法 这次主要总结的是上面黑色部分,关于文件操作的函数. 系统调用归类 * * 函数

go语言碎片整理之接口

接口 接口(interface)定义了一个对象的行为规范,只定义规范不实现,由具体的对象来实现规范的细节. 接口类型 在Go语言中接口(interface)是一种类型,是一种抽象的类型.interface是一组method的集合,是duck-type programming的一种体现.接口做的事情就像是定义一个协议(规则),只要一台机器有洗衣服和甩干的功能,我就称它为洗衣机.不关心属性(数据),只关心行为(方法).为了保护你的Go语言职业生涯,请牢记接口(interface)是一种类型. 为什么

go语言碎片整理之包

在工程化的Go语言开发项目中,Go语言的源码复用是建立在包(package)基础之上的,本文介绍了go语言中如何定义包,如何导出包的内容以及如何导入其他包. 包介绍 包(package)是多个Go源码的集合,是一种高级的代码复用方案,go语言为我们提供了很多的内置包,如fmt.os.io等. 定义包 我们还可以根据自己的需要创建自己的包,一个包可以简单理解为一个存放.go文件的文件夹.该文件夹下面的所有go文件都要在代码的第一行添加如下代码,声明该文件归属包. package 包名 注意事项:1

go语言碎片整理之 time

时间和日期是我们编程中经常用到的,本文主要介绍了Go语言内置的time包的基本用法. Go语言中导入包 单行导入 import "time" import "fmt" 多行导入 import ( "fmt" "time" ) time包 time.Time类型表示时间. func main(){ now := time.Now() fmt.Printf("current time is :%v\n",now

go语言碎片整理之标准库log

无论是软件开发的调试阶段还是软件上线之后的运行阶段,日志一直是很重要的环节,我们也应该养成在程序中记录日志的好习惯. log Go语言内置的log包实现了简单的日志服务.本文介绍了标准库log的基本使用. 使用Logger log包定义了Logger类型,该类型提供了一些格式化输出的方法.本包也提供了一个预定义的"标准"logger,可以通过调用函数Print系列(Print|Printf|Println).Fatal系列(Fatal|Fatalf|Fatalln)和Panic系列(P

go语言碎片整理之strconv

strconv包 strconv包实现额基本数据类型与其字符串表示的转换,主要有以下常用函数,Atoi().Itia().parse系列.format系列.append系列. string与int类型转换 这一组函数是我们平时用的最多的. Atoi() Atio()函数用于将字符串类型的整数转换为int类型,函数签名如下: func Atoi(s string) (i int, err error) 如果传入的字符串参数无法转换为int类型,就会报错. package main import (

目的文件已不在原目录,程序还会继续执行写文件操作吗?

最近,在现场调试程序的同事反馈回了一个问题:目的文件已不在原目录,程序还会继续执行写文件操作.我们了解了一下,具体的情况是这样的:某软件(运行在Linux下)有一个功能是在配置好的某个目录中生成文件,在文件生成的过程中,现场同事将已经生成的文件移动到了另外一个目录中:过了一段时间后发现,程序继续向移动之后的文件中写入内容,导致该文件不断增大. 为了还原现场问题,我们编写了以下程序: /********************************************************