Go 语言快速入门指南:Go 读取文本文件

简介: 工作中时不时需要读取文本,文本文件是最常见的文件类型。本文将从逐行、逐个单词和逐个字符三个方法读取文件:byLine.gobyWord.gobyCharacter.go

网络异常,图片无法展示
|

Go 读取文本文件

工作中时不时需要读取文本,文本文件是最常见的文件类型。


本文将从逐行、逐个单词和逐个字符三个方法读取文件:


  • byLine.go
  • byWord.go
  • byCharacter.go

逐行读取文本文件

逐行读取文件是最为常见的文本文件,也是最为简单的方式。首先我们需要导入几个常见的包:


  • bufio:缓存区读写文件
  • flag:命令行参数解析
package main
import (
  "bufio"
  "flag"
  "fmt"
  "io"
  "os"
)
func lineByLine(file string) error {
  var err error
  f, err := os.Open(file)
  if err != nil {
    return err
  }
  defer f.Close()
  r := bufio.NewReader(f)
  for {
    line, err := r.ReadString('\n')
    if err == io.EOF {
      break
    } else if err != nil {
      fmt.Printf("error reading file %s", err)
      break
    }
    fmt.Print(line)
  }
  return nil
}
func main() {
  flag.Parse()
  if len(flag.Args()) == 0 {
    fmt.Printf("usage: byLine <file1> [<file2> ...]\n")
    return
  }
  for _, file := range flag.Args() {
    err := lineByLine(file)
    if err != nil {
      fmt.Println(err)
    }
  }
}

代码解释:


  • 主要通过 bufio.NewReader() 函数生成一个新的读取器;
  • 随后,在 bufio.ReadString() 函数读取字符,通知该函数持续执行读取任务,直到碰到该 "\n" 参数,也就是换行符。读到换行符,执行文本输出。
  • 如果读取中断了,即 err == io.EOF ,退出文件读取
  • 或者 err != nil, 打印错误提示,退出文件执行


main() 函数中首先读取命令行参数,如果命令行长度为 0,即没有传入要读取的文件,如果此时执行 byLine.go 文件的话就会给出语法提示,如下:

$ go run byLine.go
usage: byLine <file1> [<file2> ...]


我们写一个测试的文本文件 test.txt, 写入如下几行数据,记得在第二行换行(加入空行):

这是第一行
我是第二行


运行如下命令后,结果为:

$ go run byLine.go test.txt
这是第一行
我是第二行


可以使用 cat test.txt 校验我们的结果的准确性,如下:

$ cat test.txt
这是第一行
我是第二行

逐个单词读取文本文件

package main
import (
  "bufio"
  "flag"
  "fmt"
  "os"
)
func wordByWord(file string) error {
  var err error
  f, err := os.Open(file)
  if err != nil {
    return err
  }
  defer f.Close()
  scanner := bufio.NewScanner(f)
  scanner.Split(bufio.ScanWords)
  var words []string
  for scanner.Scan() {
    words = append(words, scanner.Text())
  }
  for _, word := range words {
    fmt.Println(word)
  }
  return nil
}
func main() {
  flag.Parse()
  if len(flag.Args()) == 0 {
    fmt.Printf("usage: byWord <file1> [file2> ...]\n")
    return
  }
  for _, file := range flag.Args() {
    err := wordByWord(file)
    if err != nil {
      fmt.Println(err)
    }
  }
}


代码解释:


  • 其他代码都和 byLine.go 函数一样,主要是利用了 bufio 中的 scanner 来扫描单词,
  • scanner := bufio.NewScanner(file) 用来扫描读取的文件
  • scanner.Split(bufio.ScanWords) 用来分割单词
  • 声明一个单词字符串列表,将读取到的每一个单词放入这个列表中
  • 循环遍历单词字符串列表,打印每一个单词

测试代码

写入一个 test.txt 文件:

Hello World
1 2 3 


运行代码,结果显示:

$ go run byWord.go test.txt
Hello
World
1
2
3

逐个字符读取文本文件

逐个字符读取文本的使用场景还是很少,除非开发一个文本编辑器。新建一个 byCharacter.go 文件,然后写入如下代码:

package main
import (
  "bufio"
  "flag"
  "fmt"
  "io"
  "os"
)
func charByChar(file string) error {
  var err error
  f, err := os.Open(file)
  if err != nil {
    return err
  }
  defer f.Close()
  r := bufio.NewReader(f)
  for {
    line, err := r.ReadString('\n')
    if err == io.EOF {
      break
    } else if err != nil {
      fmt.Printf("error reading file %s", err)
      return err
    }
    for _, x := range line {
      fmt.Println(string(x))
    }
  }
  return nil
}
func main() {
  flag.Parse()
  if len(flag.Args()) == 0 {
    fmt.Printf("usage: byWord <file1> [file2> ...]\n")
    return
  }
  for _, file := range flag.Args() {
    err := charByChar(file)
    if err != nil {
      fmt.Println(err)
    }
  }
}


运行测试用例得出的最后结果为:

$ go run byCharacter.go test.txt 
H
e
l
l
o
W
o
r
l
d

总结

本文主要介绍 Go 中的 bufio 包,有些情况下,我们并不只是需要读取整个一大段文件,所以需要把文件通过某种方式读取,并介绍了 Go 读取文本文件中的三种方法:


  • 逐行读取文本文件 byLine.go
  • 逐个单词读取文本文件 byWord.go
  • 逐个字符读取文本文件 byCharacter.go


相关文章
|
4天前
|
Go API 数据库
Go 语言中常用的 ORM 框架,如 GORM、XORM 和 BeeORM,分析了它们的特点、优势及不足,并从功能特性、性能表现、易用性和社区活跃度等方面进行了比较,旨在帮助开发者根据项目需求选择合适的 ORM 框架。
本文介绍了 Go 语言中常用的 ORM 框架,如 GORM、XORM 和 BeeORM,分析了它们的特点、优势及不足,并从功能特性、性能表现、易用性和社区活跃度等方面进行了比较,旨在帮助开发者根据项目需求选择合适的 ORM 框架。
18 4
|
4天前
|
缓存 监控 前端开发
在 Go 语言中实现 WebSocket 实时通信的应用,包括 WebSocket 的简介、Go 语言的优势、基本实现步骤、应用案例、注意事项及性能优化策略,旨在帮助开发者构建高效稳定的实时通信系统
本文深入探讨了在 Go 语言中实现 WebSocket 实时通信的应用,包括 WebSocket 的简介、Go 语言的优势、基本实现步骤、应用案例、注意事项及性能优化策略,旨在帮助开发者构建高效稳定的实时通信系统。
28 1
|
7天前
|
Go
go语言中的continue 语句
go语言中的continue 语句
17 3
|
8天前
|
安全 Go 调度
探索Go语言的并发模型:goroutine与channel
在这个快节奏的技术世界中,Go语言以其简洁的并发模型脱颖而出。本文将带你深入了解Go语言的goroutine和channel,这两个核心特性如何协同工作,以实现高效、简洁的并发编程。
|
9天前
|
Go
go语言中的 跳转语句
【11月更文挑战第4天】
17 4
|
9天前
|
JSON 安全 Go
Go语言中使用JWT鉴权、Token刷新完整示例,拿去直接用!
本文介绍了如何在 Go 语言中使用 Gin 框架实现 JWT 用户认证和安全保护。JWT(JSON Web Token)是一种轻量、高效的认证与授权解决方案,特别适合微服务架构。文章详细讲解了 JWT 的基本概念、结构以及如何在 Gin 中生成、解析和刷新 JWT。通过示例代码,展示了如何在实际项目中应用 JWT,确保用户身份验证和数据安全。完整代码可在 GitHub 仓库中查看。
40 1
|
2天前
|
存储 Go PHP
Go语言中的加解密利器:go-crypto库全解析
在软件开发中,数据安全和隐私保护至关重要。`go-crypto` 是一个专为 Golang 设计的加密解密工具库,支持 AES 和 RSA 等加密算法,帮助开发者轻松实现数据的加密和解密,保障数据传输和存储的安全性。本文将详细介绍 `go-crypto` 的安装、特性及应用实例。
11 0
|
21天前
|
Go 数据安全/隐私保护 开发者
Go语言开发
【10月更文挑战第26天】Go语言开发
33 3
|
23天前
|
Java 程序员 Go
Go语言的开发
【10月更文挑战第25天】Go语言的开发
29 3
|
3月前
|
JSON 中间件 Go
go语言后端开发学习(四) —— 在go项目中使用Zap日志库
本文详细介绍了如何在Go项目中集成并配置Zap日志库。首先通过`go get -u go.uber.org/zap`命令安装Zap,接着展示了`Logger`与`Sugared Logger`两种日志记录器的基本用法。随后深入探讨了Zap的高级配置,包括如何将日志输出至文件、调整时间格式、记录调用者信息以及日志分割等。最后,文章演示了如何在gin框架中集成Zap,通过自定义中间件实现了日志记录和异常恢复功能。通过这些步骤,读者可以掌握Zap在实际项目中的应用与定制方法
135 1
go语言后端开发学习(四) —— 在go项目中使用Zap日志库