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

作者:Dechin's 时间:2023-03-23 12:27:20 

目录
  • 行遍历实现

  • linecache实现

  • 命令行sed获取

  • 总结概要

行遍历实现

在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

来源:https://www.cnblogs.com/dechinphy/p/lbl.html

标签:python,读取,行
0
投稿

猜你喜欢

  • Flask框架利用Echarts实现绘制图形

    2023-01-08 11:52:42
  • bpython 功能强大的Python shell

    2022-05-08 22:12:06
  • MySQL修改默认引擎和字符集详情

    2024-01-14 21:37:27
  • Python3几个常见问题的处理方法

    2022-08-04 10:48:56
  • 基于Python自制一个文件解压缩小工具

    2021-10-15 14:28:00
  • ASP进阶教程Ⅶ:留言簿设置密码验证

    2008-10-13 09:02:00
  • k8s容器互联-flannel host-gw原理篇

    2024-04-27 15:40:07
  • python读取Kafka实例

    2023-10-22 17:22:58
  • Python实现的微信公众号群发图片与文本消息功能实例详解

    2023-02-04 07:43:48
  • MySQL应用技巧之存取权限

    2010-08-08 09:10:00
  • Python list sort方法的具体使用

    2023-01-14 22:27:46
  • Java正则表达式循环匹配字符串方式

    2023-07-25 03:29:48
  • Go Web 编程中的模板库应用指南(超详细)

    2024-02-05 20:50:55
  • Go语言实现请求超时处理的方法总结

    2024-04-23 09:37:50
  • Elasticsearch的删除映射类型操作示例

    2022-05-03 09:46:50
  • python 正则式 概述及常用字符

    2023-01-14 14:50:54
  • Selenium常见八大定位法总结

    2022-07-05 02:16:21
  • 如何测试字符串的长度?

    2009-11-11 20:02:00
  • Vue使用localStorage存储数据的方法

    2024-04-30 10:23:47
  • 如何做一个只搜索本网站的引擎?

    2010-07-12 19:02:00
  • asp之家 网络编程 m.aspxhome.com