4.1 KiB
4.1 KiB
File
暂无介绍...
目录导航
列出了该 package
下所有的函数及类型定义,可通过目录导航进行快捷跳转 ❤️
展开 / 折叠目录导航
包级函数定义
函数名称 | 描述 |
---|---|
PathExist | 路径是否存在 |
IsDir | 路径是否是文件夹 |
WriterFile | 向特定文件写入内容 |
ReadOnce | 单次读取文件 |
ReadBlockHook | 分块读取文件 |
ReadLine | 分行读取文件 |
LineCount | 统计文件行数 |
Paths | 获取指定目录下的所有文件路径 |
ReadLineWithParallel | 并行的分行读取文件并行处理,处理过程中会将每一行的内容传入 handlerFunc 中进行处理 |
FindLineChunks | 查找文件按照每行划分的分块,每个分块的大小将在 chunkSize 和分割后的分块距离行首及行尾的距离中范围内 |
FindLineChunksByOffset | 该函数与 FindLineChunks 类似,不同的是该函数可以指定 offset 从指定位置开始读取文件 |
详情信息
func PathExist(path string) (bool, error)
路径是否存在
func IsDir(path string) (bool, error)
路径是否是文件夹
func WriterFile(filePath string, content []byte) error
向特定文件写入内容
func ReadOnce(filePath string) ([]byte, error)
单次读取文件
- 一次性对整个文件进行读取,小文件读取可以很方便的一次性将文件内容读取出来,而大文件读取会造成性能影响。
func ReadBlockHook(filePath string, bufferSize int, hook func (data []byte)) error
分块读取文件
- 将filePath路径对应的文件数据并将读到的每一部分传入hook函数中,当过程中如果产生错误则会返回error。
- 分块读取可以在读取速度和内存消耗之间有一个很好的平衡。
func ReadLine(filePath string, hook func (line string)) error
分行读取文件
- 将filePath路径对应的文件数据并将读到的每一行传入hook函数中,当过程中如果产生错误则会返回error。
func LineCount(filePath string) int
统计文件行数
func Paths(dir string) []string
获取指定目录下的所有文件路径
- 包括了子目录下的文件
- 不包含目录
func ReadLineWithParallel(filename string, chunkSize int64, handlerFunc func ( string), start ...int64) (n int64, err error)
并行的分行读取文件并行处理,处理过程中会将每一行的内容传入 handlerFunc 中进行处理
- 由于是并行处理,所以处理过程中的顺序是不确定的。
- 可通过 start 参数指定开始读取的位置,如果不指定则从文件开头开始读取。
func FindLineChunks(file *os.File, chunkSize int64) [][2]int64
查找文件按照每行划分的分块,每个分块的大小将在 chunkSize 和分割后的分块距离行首及行尾的距离中范围内
- 使用该函数得到的分块是完整的行,不会出现行被分割的情况
- 当过程中发生错误将会发生 panic
- 返回值的成员是一个长度为 2 的数组,第一个元素是分块的起始位置,第二个元素是分块的结束位置
func FindLineChunksByOffset(file *os.File, offset int64, chunkSize int64) [][2]int64
该函数与 FindLineChunks 类似,不同的是该函数可以指定 offset 从指定位置开始读取文件