python3读取文件指定行的三种方法


Posted in Python onMay 24, 2021

行遍历实现

在python中如果要将一个文件完全加载到内存中,通过file.readlines()即可,但是在文件占用较高时,我们是无法完整的将文件加载到内存中的,这时候就需要用到python的file.readline()进行迭代式的逐行读取:

filename = 'hello.txt'

with open(filename, 'r') as file:
    line = file.readline()
    counts = 1
    while line:
        if counts >= 50000000:
            break
        line = file.readline()
        counts += 1

这里我们的实现方式是先用一个with语句打开一个文件,然后用readline()函数配合while循环逐行加载,最终通过一个序号标记来结束循环遍历,输出文件第50000000行的内容。该代码的执行效果如下:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ time python3 get_line.py 

real    0m10.359s
user    0m10.062s
sys     0m0.296s

可以看到这里的耗时为10s多一些。

linecache实现

虽然在python的readline函数中并没有实现读取指定行内容的方案,但是在另一个库linecache中是实现了的,由于使用的方式较为简单,这里直接放上代码示例供参考:

filename = 'hello.txt'

import linecache
text = linecache.getline(filename, 50000000)

该代码的执行结果如下:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ time python3 get_line.py 

real    0m11.904s
user    0m5.672s
sys     0m6.231s

虽然在实现方式上简化了许多,但是我们发现这个实现的用时超过了11s,还不如我们自己手动实现的循环遍历方案。因此如果是对于性能有一定要求的场景,是不建议采用这个方案的。

命令行sed获取

我们知道用Linux系统本身自带的sed指令也是可以获取到文件指定行或者是指定行范围的数据的,其执行指令为:sed -n 50000000p filename即表示读取文件的第50000000行的内容。同时结合python的话,我们可以在python代码中执行系统指令并获取输出结果:

filename = 'hello.txt'

import os
result = os.popen('sed -n {}p {}'.format(50000000, filename)).read()

需要注意的是,如果直接运行os.system()是没有返回值的,只有os.popen()是有返回值的,并且需要在尾巴加上一个read()的选项。该代码的执行结果如下:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ time python3 get_line.py 

real    0m2.532s
user    0m0.032s
sys     0m0.020s

可以看到直接使用sed指令的执行速度很快,但是用这种方法并不是一本万利的,比如以下这个例子:

filename = 'hello.txt'

import os
result = os.popen('sed -n {}p {}'.format(500, filename)).read()

我们把读取第50000000行内容改为读取第500行的内容,再运行一次程序:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ time python3 get_line.py 

real    0m2.540s
user    0m0.037s
sys     0m0.013s

然而我们发现这个速度并没有因为要读取的行数减少了而变少,而是几乎保持不变的。

总结概要

本文通过4个测试案例分析了在python中读取文件指定行内容的方案,并得到了一些运行耗时的数据。从需求上来说,如果是对于小规模的数据,比如几百行规模的数据,建议使用readline循环遍历来操作,速度也相当不错,或者是linecache中的函数实现也是可以的,甚至可以直接用readlines将整个文本内容加载到内存中。但是对于数据规模比较大的场景,比如超过了千万行的级别,那么使用sed指令的方式对指定行内容进行读取的方式,应该是所有方式中最快速的。

本文首发链接为:https://www.cnblogs.com/dechinphy/p/lbl.html

作者ID:DechinPhy

以上就是python3读取文件指定行的三种方法的详细内容,更多关于python读取文件指定行的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
跟老齐学Python之dict()的操作方法
Sep 24 Python
python中的字典使用分享
Jul 31 Python
利用selenium 3.7和python3添加cookie模拟登陆的实现
Nov 20 Python
Python方法的延迟加载的示例代码
Dec 18 Python
PyTorch线性回归和逻辑回归实战示例
May 22 Python
Python中交换两个元素的实现方法
Jun 29 Python
APIStar:一个专为Python3设计的API框架
Sep 26 Python
Python正则表达式匹配日期与时间的方法
Jul 07 Python
Python3进制之间的转换代码实例
Aug 24 Python
Python3 使用pillow库生成随机验证码
Aug 26 Python
Django实现简单的分页功能
Feb 22 Python
详解Python小数据池和代码块缓存机制
Apr 07 Python
pytorch中Schedule与warmup_steps的用法说明
May 24 #Python
Python Pycharm虚拟下百度飞浆PaddleX安装报错问题及处理方法(亲测100%有效)
May 24 #Python
pytorch交叉熵损失函数的weight参数的使用
May 24 #Python
pytorch 实现变分自动编码器的操作
May 24 #Python
Pytorch数据读取之Dataset和DataLoader知识总结
May 23 #Python
Python基础之函数嵌套知识总结
May 23 #Python
利用python Pandas实现批量拆分Excel与合并Excel
May 23 #Python
You might like
php数字转汉字代码(算法)
2011/10/08 PHP
php实现微信企业转账功能
2018/10/02 PHP
PHP设计模式之抽象工厂模式实例分析
2019/03/25 PHP
Laravel 实现在Blade模版中使用全局变量代替路径的例子
2019/10/22 PHP
php 多个变量指向同一个引用($b = &$a)用法分析
2019/11/13 PHP
xml 与javascript结合的问题解决方法
2007/03/24 Javascript
JavaScript 操作键盘的Enter事件(键盘任何事件),兼容多浏览器
2010/10/11 Javascript
让元素在网页中可拖动示例代码
2013/08/13 Javascript
js实现touch移动触屏滑动事件
2015/04/17 Javascript
小心!AngularJS结合RequireJS做文件合并压缩的那些坑
2016/01/09 Javascript
JavaScript实现的MD5算法完整实例
2016/02/02 Javascript
JavaScript解析JSON格式数据的方法示例
2017/01/24 Javascript
关于react-router的几种配置方式详解
2017/07/24 Javascript
使用mint-ui开发项目的一些心得(分享)
2017/09/07 Javascript
原生实现一个react-redux的代码示例
2018/06/08 Javascript
详解Vue webapp项目通过HBulider打包原生APP(vue+webpack+HBulider)
2019/02/02 Javascript
react-intl实现React国际化多语言的方法
2020/09/27 Javascript
基于JavaScript实现轮播图效果
2021/01/02 Javascript
[00:37]食人魔魔法师轮盘吉兆顺应全新至宝将拥有额外款式
2019/12/19 DOTA
Ubuntu下安装PyV8
2016/03/13 Python
python读取excel表格生成erlang数据
2017/08/26 Python
基于django channel实现websocket的聊天室的方法示例
2019/04/11 Python
解决pycharm 远程调试 上传 helpers 卡住的问题
2019/06/27 Python
Python实现语音识别和语音合成功能
2019/09/20 Python
浅析python redis的连接及相关操作
2019/11/07 Python
学Python 3的理由和必要性
2019/11/19 Python
Pandas的数据过滤实现
2021/01/15 Python
elf彩妆英国官网:e.l.f. Cosmetics英国(美国平价彩妆品牌)
2017/11/02 全球购物
化工机械应届生求职信
2013/11/04 职场文书
实训报告范文大全
2014/11/04 职场文书
2014年文秘工作总结
2014/11/25 职场文书
实习介绍信模板
2015/01/30 职场文书
2015年医务人员医德医风自我评价
2015/03/03 职场文书
2015年医德考评自我评价
2015/03/03 职场文书
培训心得体会怎么写
2016/01/25 职场文书
MySQL池化框架学习接池自定义
2022/07/23 MySQL