08.5.3 逐字符读取文本文件
在本节中,你将学会如何逐字符读取文本文件,这是一个非常少见的需求,除非你想创建文本编辑器。相关的Go
代码参考byCharacter.go
,将分为四部分介绍。
byCharacter.go
第一部分代码如下:
如你所见,本程序不需要使用正则表达式。
byCharacter.go
第二部分代码如下:
byCharacter.go
第三部分代码如下:
此处,你读取每一行,并使用range
分割。range
返回两个值:丢弃第一个值,它是line
变量中当前字符的位置,并使用第二个值。但是,该值不是字符-这就是为什么必须使用string()
函数将其转换为字符的原因。
注意,由于fmt.Println(string(x))
语句,每个字符都按行打印,这意味着程序的输出将很大。如果想要压缩输出,应该使用fmt.Print()
函数。
byCharacter.go
的最后一部分代码如下:
执行byCharacter.go
会产生如下输出:
注意,上述Go
代码也能用来统计输入文件的字符个数,即是Go
版本的wc(1)
命令行实现。
Last updated