Go语言文件操作

如何打开和关闭文件

  • 在Go语言中的OS包提供了一个函数,叫做open,就是专门用来打开文件的
os.Open( " 文件路径 ")
  • 在Go语言中OS包中提供了关闭文件的函数
os.Close()
  • 注意点

    • 如果文件不存在是不会自动创建的
    • 通过Open打开的文件只能读取不能写入
    • 记得打开的时候同时写上关闭文件的函数
  • 示例

package main

import (
   "fmt"
   "os"
)

func main(){

   //打开文件
   fp,err := os.Open("D:/xt.txt")
   if err != nil {
      fmt.Println("打开失败")
   }else{
      fmt.Println(fp)  // &{0xc042082780}  文件的地址
   }
   //关闭文件
   defer func() {
      if err := fp.Close();err !=nil {
         fmt.Println("关闭文件失败")
      }
   }()

}

读取文件

第一种读取方式OS包
  • 通过OS包中Read函数读取
func (f *file) Read (b []byte) (n int , err error)
  • 注意点
  1. Read函数会将读取到的数据放到指定的切片中,并且会一次性读取所有的数据
  2. 会将读取到的byte个数返回给我们,并且还会返回一个error
  3. 如果读取成功 那么error 等于 nil 如果读取失败那么error就不等于nil
package main

import (
   "fmt"
   "os"
)

func main(){

   //打开文件
   fp,err := os.Open("D:/xt.txt")
   if err != nil {
      fmt.Println("打开失败")
   }else{
      fmt.Println(fp)
   }
   //关闭文件
   defer func() {
      if err := fp.Close();err !=nil {
         fmt.Println("关闭文件失败")
      }
   }()


   // 读取文件
   buff := make([]byte,10)

   len,err := fp.Read(buff)

   if err != nil{
      fmt.Println("读取失败")
   }else {
      fmt.Println(len)                 // len = 9 
      fmt.Println(string(buff))        // 132456789
      fmt.Println(string(buff[:len]))  // 123456789
   }

}
  • 读取所有数据
 // 读取所有文件
   buff := make([]byte,7)  // 定义切片保存读取到的数据
   for{
      //先读取7个
      len,err := fp.Read(buff)
      if err !=nil && len<=0 {
         break
      }
      // 将读取到的数据转换为字符串打印
      fmt.Print(string(buff[:len]))
   }

第二种读取方式 bufio 包
  • 通过bufio 包中的ReadBytes 和 ReadString 函数

  • ReadBytes函数

  1. line [] byte--->会返回一个切片给我们
  2. delim byte ---->参数接收 读取结束的标志
  3. 由于会讲换行也读取出来所以如果数据最后没有换行会少读取一行(先判断错误的情况下)
func ( b *reader) ReadBytes( delim byte ) (line [] byte , err error) 
  • 会创建缓冲区
    缓冲区默认大小4096
  • 创建缓冲区的方法
bufio . NewReader( fp )
  • 实例
package main

import (
   "bufio"
   "fmt"
   "os"
)

func main(){

   //打开文件
   fp,err := os.Open("D:/xt.txt")

   if err != nil {
      fmt.Println("打开失败")
   }else {
      fmt.Println(fp)
   }

   //关闭文件
   defer func() {
      if err := fp.Close();err != nil {
         fmt.Println("关闭文件失败")
      }
   }()

   // 创建缓冲区 fp传给NewReader函数
   readArea  := bufio.NewReader(fp)

   buff,err := readArea .ReadBytes('\n') // 读取到\n 结束

   if err != nil {
      fmt.Println("读取失败")
   }else {
      fmt.Print(string(buff))  // 此步骤决定是否少读取一行
   }

}
  • ReadString 函数
package main

import (
   "bufio"
   "fmt"
   "os"
)

func main(){

   //打开文件
   fp,err := os.Open("D:/xt.txt")

   if err != nil {
      fmt.Println("打开失败")
   }else {
      fmt.Println(fp)
   }

   //关闭文件
   defer func() {
      if err := fp.Close();err != nil {
         fmt.Println("关闭文件失败")
      }
   }()

   // 创建缓冲区 fp传给NewReader函数
   readArea := bufio.NewReader(fp)

   str,err := readArea .ReadString('\n') // 读取到\n 结束

   if err != nil {
      fmt.Println("读取失败")
   }else {
      fmt.Print(str)
   }

}

第三种读取方式 ioutil 包
ioutil . ReadFile ( "文件路径" )
  • 参数 读取文件的路径
  • 返回值1 读取到的数据
  • 返回值2 读取是否成功的error
package main

import (
   "fmt"
   "io/ioutil"
)

func main(){
   
   buff,err := ioutil.ReadFile("D:/xt.txt")

   if err != nil {
      fmt.Println("读取失败")
   }else {
      fmt.Println(string(buff))  // 123456789
   }

}

文件的写入

第一种写入方式 os包中的 write函数
  • 由于Open函数打开文件只能读取,不能写入
  • 所以要用create函数
  • 注意点
  1. create函数作用是创建一个文件
  2. 文件如果不存在,会自动创建一个新的
  3. 文件存在,会覆盖掉以前的文件(想当于创建一个新的替换掉)
  • 案例
package main

import (
   "fmt"
   "os"
)

func main(){
   //创建文件
   fp,err := os.Create("D:/jianshu.txt")
   if err != nil {
      fmt.Println("打开文件失败")
      return
   }
   //关闭文件
   defer func() {
      if err := fp.Close();err != nil {
         fmt.Println("关闭文件失败")
      }
   }()
   
   //创建写入的内容
   buff := []byte{'w','w','w','.','j','i','a','n','s','h','u','.','c','o','m'}
   //写入到文件中
   len,err := fp.Write(buff)
   if err != nil {
      fmt.Println("写入失败")
   }else {
      fmt.Println("写入",len,"个字符")
   }
}

第二种写入方式 bufio 包中的Write 和 WriteString
  • 创建缓冲区
bufio.NewWrite( )
  • 注意点:
    如果通过带缓冲区的方式写入数据, 那么必须在写入完毕之后刷新一下缓冲区, 才会将缓冲区中的数据真正的写入到文件中
Flush() ----> 刷新函数
  • 案例
package main

import (
   "bufio"
   "fmt"
   "os"
)

func main(){
   //打开文件
   fp,err := os.Create("D:/jianshu.txt")
   if err != nil {
      fmt.Println("打开文件失败")
      return
   }
   //关闭文件
   defer func() {
      if err := fp.Close();err != nil {
         fmt.Println("关闭文件失败")
      }
   }()

   // 创建缓冲区
   writeArea := bufio.NewWriter(fp)

   //创建写入的内容
   buff := []byte{'w','w','w','.','j','i','a','n','s','h','u','.','c','o','m'}
   //写入到文件中
   len,err := writeArea.Write(buff)

   if err != nil {
      fmt.Println("写入失败")
   }else {
      fmt.Println("写入",len,"个字节")
   }

   // 刷新缓冲区
   writeArea.Flush()

}

WriteString 函数

  • 格式
WriteString( "写入的内容" )
package main

import (
   "bufio"
   "fmt"
   "os"
)

func main(){
   //打开文件
   fp,err := os.Create("D:/jianshu.txt")
   if err != nil {
      fmt.Println("打开文件失败")
      return
   }
   //关闭文件
   defer func() {
      if err := fp.Close();err != nil {
         fmt.Println("关闭文件失败")
      }
   }()

   // 创建一个写入缓冲区
   writeArea := bufio.NewWriter(fp)

   len,err := writeArea.WriteString("天下足球,最纯粹的足球,最高级的享受")

   if err != nil {
      fmt.Println("写入失败")
   }else {
      fmt.Println("写入",len,"个字节")
   }

   / / 刷新缓冲区
   writeArea.Flush()

}
  • 刷新缓冲区 Flush


Os包中的OpenFile 打开文件 函数
  • 作用
  1. 打开一个文件, 如果文件不存在,会创建这个文件
  • 参数
  1. 第一个参数 : 需要打开文件的路径
  2. 第二个参数 : 以什么模式打开 , 可以写多个模式,多个模式之间用 | 分开
const (
        O_RDONLY int = syscall.O_RDONLY    只读模式打开文件
        O_WRONLY int = syscall.O_WRONLY    只写模式打开文件
        O_RDWR   int = syscall.O_RDWR      读写模式打开文件
        O_APPEND int = syscall.O_APPEND    写操作时将数据附加到文件尾部
        O_CREATE int = syscall.O_CREAT     如果不存在将创建一个新文件
        O_EXCL   int = syscall.O_EXCL      和O_CREATE配合使用,文件必须不存在
        O_SYNC   int = syscall.O_SYNC      打开文件用于同步I/O
        O_TRUNC  int = syscall.O_TRUNC     如果可能,打开时清空文件
    )
  1. 第三个参数: 指定文件的权限, 只对Linux系统有效, 在Windows下无效
0.没有任何权限
    1.执行权限(如果是可执行程序, 可以运行)
    2.写权限
    3.写权限和执行权限
    4.读权限
    5.读权限和执行权限
    6.读权限和写权限
    7.读权限和写权限以及执行权限
    一般情况下写 0666
  • 注意点
    OpenFile和Open函数一样, 打开文件之后需要手动关闭文件

  • 案例

package main

import (
   "fmt"
   "os"
)

func main(){

   fp,err := os.OpenFile("D:/jianshu.txt", os.O_APPEND | os.O_RDWR,0666)

   if err != nil {
      fmt.Println("打开失败")
   }
   defer func() {
      if err:=fp.Close();err != nil {
         fmt.Println("关闭文件失败")
      }
   }()

   buff := []byte{'a','b','c'}

   len,err := fp.Write(buff)
   if err != nil {
      fmt.Println("写入成功")
   }else {
      fmt.Println("写入字符",len)
   }

}

第三种方式通过 ioutil 包中的WriteFile
func WriteFile(  filename string,  data []byte,   perm os.FileMode ) error 
  • 第一个参数 文件路径
  • 第二个参数 写入的内容
  • 第三个参数 写入权限
package main

import (
    "fmt"
    "io/ioutil"
)

func main() {
    buf := []byte{'x','x','x','\r','\n'}
    err := ioutil.WriteFile("D:/jianshu.txt", buf, 0666)
    if err != nil{
        fmt.Println("写入数据失败")
    }else{
        fmt.Println("写入数据成功")
    }
}

待续

你可能感兴趣的:(Go语言文件操作)