Skip to main content

moregeek program

一文掌握 go 文件的读取操作_wx6372efec77838的博客-多极客编程

耐心和持久胜过激烈和狂热。

哈喽大家好,我是陈明勇,今天分享的知识是 Go 文件的读取操作。如果本文对你有帮助,不妨点个赞,如果你是 Go 语言初学者,不妨点个关注,一起成长一起进步,如果本文有错误的地方,欢迎指出!

os 包 和 bufio 包

Go 标准库的 ​​os​​ 包,为我们提供很多操作文件的函数,如 ​​Open(name)​​ 打开文件、​​Create(name)​​ 创建文件等函数,与之对应的是 ​​bufio​​ 包,​​os​​ 包是直接对磁盘进行操作的,而 ​​bufio​​ 包则是带有缓冲的操作,不用每次都去操作磁盘。

os.Open 与 os.OpenFile 以及 File.Read

  • ​Open(name string) (*File, error)​
    通过 文件名文件路径+文件名 的形式打开一个文件,此文件只能用于读操作,如果文件不存在则返回 ​​PathError​​ 。
  • 参数 ​​name​​ 为文件名文件路径+文件名
  • 返回值 ​​*File​​ 为一个 ​​File​​ 结构体的指针类型,通过指针可以对文件进行读写等操作。
  • 返回值 ​​error​​ 为打开文件的过程中产生的错误。
  • ​OpenFile(name string, flag int, perm FileMode) (*File, error)​
    通过指定 文件名文件路径+文件名、文件操作模式、文件权限三个参数打开一个文件,之后可对此文件进行读写操作。
  • 参数 ​​name​​ 为文件名文件路径+文件名
  • 参数 ​​flag​​ 为指定文件操作模式,可选值有 ​​O_RDONLY​​ → 只读操作、​​O_WRONLY​​ → 只写操作、​​O_RDWR​​ → 读写操作、​​O_APPEND​​ → 写入时向文件追加数据、​​O_CREATE​​ → 如果不存在,则创建一个新文件等。
  • 参数 ​​perm​​ 参数表示文件的模式和权限,例如 ​​0666​​ 为读写权限。如果对文件权限所对应的数字不了解,可以去学习一下。
  • 返回值 ​​*File​​ 为一个 ​​File​​ 结构体的指针类型,通过指针可以对文件进行读写等操作。
  • 返回值 ​​error​​ 为打开文件的过程中产生的错误。
  • ​File.Read(b []byte) (n int, err error)​
    读取与 ​​b​​ 等长度的字节,并存储到 ​​b​​ 里面。
  • 参数 ​​b​​ 为一个切片数组,用于指定读取长度和存储字节数据。
  • 返回值 ​​n​​ 为所读取字节的长度。
  • 返回值 ​​error​​ 为读取字节的过程中产生的错误。

读取文件操作

import (
"fmt"
"os"
)

func main() {
file, err := os.Open("1.txt")
if err != nil {
fmt.Println(err)
return
}
defer file.Close()
data := make([]byte, 11)
count, err := file.Read(data)
if err != nil {
return
}
fmt.Println("字节数据:", data) // [72 101 108 108 111 32 119 111 114 108 100]
fmt.Println("字符串数据:", string(data)) // Hello world
fmt.Println("所获取字节的长度:", count) // 11
}

执行结果:

字节数据: [72 101 108 108 111 32 119 111 114 108 100]
字符串数据: Hello world
所获取字节的长度: 11
  • 首先通过 ​​Open​​ 函数打开 ​​1.txt​​ 文件,用 ​​file​​ 变量接收,默认为可读模式;
  • 然后创建一个长度为 ​​11​​ 的字节切片,接着通过 ​​file​​ 变量的方法 ​​Read​​ 读取长度为 ​​11​​ 的字节数据。​​os.Open("1.txt")​​ 等价于 ​​os.OpenFile("1.txt", os.O_RDONLY, 0)​​。
  • 最后打印读取到的数据。

bufio.NewReader 和 Reader.ReadString

读取文件,建议使用 ​​bufio.NewReader​​ 和 ​​Reader.ReadString​​,减少磁盘的操作。

  • ​NewReader(rd io.Reader) *Reader​
    获取一个有缓冲区的 ​​Reader​​ 指针变量,缓冲区默认大小为 ​​4096​​ 字节。通过变量可以对数据进行读操作。
  • 参数 ​​rd​​ 为一个接口,实现这个接口的数据类型变量都可以作为参数,例如上面提到的 ​​File​​。
  • 返回值 ​​*Reader​​ 为 ​​Reader​​ 结构体的指针,通过指针可以读取缓冲区的数据。
  • ​ReadString(delim byte) (string, error)​
    读取数据,直到第一次遇到分隔符 ​​delim​​ 为止。读取过程中发生错误会返回 ​​EOF​​ 错误信息。
  • 参数 ​​delim​​ 为分隔符,每次读取时遇到分隔符就会终止。
  • 第一个返回值为所读取的内容,内容包括分隔符。
  • 第二个返回值为读取过程中产生的错误信息。

读取文件操作

​1.txt​​ 文件的内容为:

Hello world
Hello Golang
Hello Gopher
import (
"bufio"
"fmt"
"io"
"os"
"strings"
)

func main() {
file, err := os.OpenFile("1.txt", os.O_RDONLY, 0)
if err != nil {
fmt.Println(err)
return
}
defer file.Close()
reader := bufio.NewReader(file)
for {
if lineData, err := reader.ReadString('\n'); err != nil {
if err == io.EOF {
// 因为是以换行符为分隔符,如果最后一行没有换行符,那么返回 io.EOF 错误时,也是可能读到数据的,因此判断一下是否读到了数据
if len(lineData) > 0 {
fmt.Println(lineData)
}
break
}
} else {
fmt.Println(strings.TrimRight(lineData, "\n"))
}
}
}

执行结果:

Hello World
Hello Golang
Hello Gopher
  • 首先通过 ​​OpenFile​​ 函数打开 ​​1.txt​​ 文件,用 ​​file​​ 变量接收,指定为可读模式;
  • 然后通过 ​​NewReader​​ 函数创建一个缓冲区,将默认长度的字节读取到缓冲区中;
  • 接着通过 ​​Reader​​ 结构体的方法 ​​ReadString​​,以 ​​\n​​ 为分隔符,按行读取数据,然后打印数据。
  • 其中有一个注意点就是,因为是以换行符为分隔符,如果最后一行没有换行符,那么返回 ​​io.EOF​​ 错误时,也是可能读到数据的,因此需要判断一下是否读到了数据。

小结

本文先是对 ​​os​​ 包 和 ​​bufio​​ 包进行简单的介绍,然后介绍 ​​os​​ 包里的 ​​Open​​ 和 ​​OpenFile​​ 函数以及 ​​File​​ 结构体的方法 ​​Read​​,通过案例展示它们的使用方式。紧接着引出 ​​bufio​​ 包里的 ​​NewReader​​ 函数和 ​​Reader​​ 结构体的方法 ​​ReadString​​,读取文件的操作推荐使用它们,能减少对磁盘的操作,高效读取数据。

©著作权归作者所有:来自51CTO博客作者CMY陈明勇的原创作品,请联系作者获取转载授权,否则将追究法律责任

dapp实战:开发属于你的第一个dapp - 我的日记本_sleep666的博客-多极客编程

效果预览项目的视频教程部分已经发布到了b站​​https://space.bilibili.com/391924926/channel/seriesdetail?sid=2745034​​初始化状态添加删除开发环境准备系统环境RemixGanachenodejs最新版metamask开发框架vue-cli脚手架web3.jselement-uivue-cli脚手架创建工程vue create my

数据挖掘算法-knn算法_domi+1的博客-多极客编程

✅作者简介:热爱科研的算法开发者,Python、Matlab项目可交流、沟通、学习。 🍎个人主页:算法工程师的学习日志算法简介邻近算法,又叫K近邻(kNN,k-NearestNeighbor)分类算法是数据挖掘分类技术中最简单的方法之一。所谓K最近邻,就是k个最近的邻居的意思,说的是每个样本都可以用它最接近的k个邻居来代表。个人感觉KNN算法(K-NearestNeighbor)一种极其简单粗暴的

自动控制-滑模控制_domi+1的博客-多极客编程

✅作者简介:热爱科研的算法开发者,Python、Matlab项目可交流、沟通、学习。 🍎个人主页:算法工程师的学习日志滑模控制是一种相当简单而且控制性能优越的控制方法。它的控制效果优越体现在哪里呢?主要是两点:1、滑动模态可以进行设计,调节的参数少,响应速度快。2、对扰动不灵敏。什么是干扰?如果你的机器好端端地在工作,突然来了一个熊孩子拿起一钉锤就是一顿敲;或者工厂附近有高铁,每隔一段时间地面就要

数组_江湖良人的博客-多极客编程

创建数组#include<stdio.h>#include<string.h>int main(){ int arr1[10]={1,2,3}; char arr2[5]={'a',98}; char arr3[5]="ab" char arr4[]="abcdef" printf("%d",strlen(arr4)); printf("%d",sizeof(a

【linux操作系统】vim编辑器和管道与重定向命令以及u盘备份文件学习详解_上进小菜猪的博客-多极客编程

一.TTP是什么 终端是一种字符型设备,它有多种类型,通常使用tty来简称各种类型的终端设备。 tty是Teletype的缩写。Teletype是最早出现的一种终端设备,是由Teletype公司生产的。设备名放在特殊文件目录/dev/下。 二.vim编辑器 基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode),输入模式(Insert mode)和底线命令模式(Last

c语言从入门到实战(基础学习篇)_晚风挽着浮云的博客-多极客编程

1. 基本数据类型原码 反码和补码 正数的反码是其本身负数的反码是在其源码的基础上,符号位不变,其余各个位取反负数的补码是在其原码的基础上,符号位不变,其余各位取反,最后+1 1.1整数类型int 占用4个字节 32个比特 long 占用8个字节 64个比特short 占用2个字节 16个比特 1.2浮点类型浮点类型一般用于保存小数,不过为啥不叫小数类型而选浮点类型呢?因为我们的一个小数分为整数部

一文了解 go 接口_wx6372efec77838的博客-多极客编程

耐心和持久胜过激烈和狂热。哈喽大家好,我是陈明勇,今天分享的知识是 Go 接口。如果本文对你有帮助,不妨点个赞,如果你是 Go 语言初学者,不妨点个关注,一起成长一起进步,如果本文有错误的地方,欢迎指出!接口在 ​​Go​​ 语言中,接口是一种抽象的类型,是一组方法的集合。接口存在的目的是定义规范,而规范的细节由其他对象去实现。我们来看一个例子:import "fmt"type Person st

一文初探 go reflect 包_wx6372efec77838的博客-多极客编程

耐心和持久胜过激烈和狂热。哈喽大家好,我是陈明勇,今天分享的知识是 Go reflect 包的基本使用。如果本文对你有帮助,不妨点个赞,如果你是 Go 语言初学者,不妨点个关注,一起成长一起进步,如果本文有错误的地方,欢迎指出!reflect 反射包针对反射,​​Go​​ 提供了 ​​reflect​​ 包,使用这个包里的函数可以在程序运行时获取和更新未知变量的值,操作未知变量的方法等。​refl

一文了解 go 方法_wx6372efec77838的博客-多极客编程

耐心和持久胜过激烈和狂热。哈喽大家好,我是陈明勇,今天分享的知识是 Go 方法。如果本文对你有帮助,不妨点个赞,如果你是 Go 语言初学者,不妨点个关注,一起成长一起进步,如果本文有错误的地方,欢迎指出!前言在前面的 ​​一文熟悉 Go 函数 ​​ 文章中,介绍了 Go 函数的声明,函数的几种形式如匿名函数、闭包、基于函数的自定义类型和函数参数详解等,而本文将对方法进行介绍,方法的本质就是函数,介

一文掌握 go 文件的写入操作_wx6372efec77838的博客-多极客编程

耐心和持久胜过激烈和狂热。哈喽大家好,我是陈明勇,今天分享的知识是 Go 文件的写入操作。如果本文对你有帮助,不妨点个赞,如果你是 Go 语言初学者,不妨点个关注,一起成长一起进步,如果本文有错误的地方,欢迎指出!前言上篇文章 ​​一文掌握 Go 文件的读取操作 ​​​ 介绍了如何使用 ​​Go​​​ ​​os​​​ 包和 ​​bufio​​ 包里的几个函数和方法,通过案例展示如何读取文件里的内容

只会用 go 写 o(n²) 的冒泡排序算法?来看看优化后最好情况下的 o(n) 算法吧_wx6372efec77838的博客-多极客编程

耐心和持久胜过激烈和狂热。哈喽大家好,我是陈明勇,今天分享的内容是使用 Go 实现冒泡排序算法。如果本文对你有帮助,不妨点个赞,如果你是 Go 语言初学者,不妨点个关注,一起成长一起进步,如果本文有错误的地方,欢迎指出!冒泡排序冒泡排序是交换排序中最简单的一种算法。 算法思路:遍历数组,相邻的两个元素进行比较,以升序为例,如果前面的元素大于后面的元素,则将它们的位置进行交换第一轮遍历结束之后,最大

go 实现选择排序算法_wx6372efec77838的博客-多极客编程

耐心和持久胜过激烈和狂热。哈喽大家好,我是陈明勇,今天分享的内容是使用 Go 实现选择排序算法。如果本文对你有帮助,不妨点个赞,如果你是 Go 语言初学者,不妨点个关注,一起成长一起进步,如果本文有错误的地方,欢迎指出!选择排序选择排序是一种简单的比较排序算法,它的算法思路是首先从数组中寻找最小(大)的元素,然后放到数组中的第一位,接下来继续从未排序的数组中寻找最小(大)元素,然后放到已排序数组的