博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用Python读取大文件
阅读量:6478 次
发布时间:2019-06-23

本文共 1674 字,大约阅读时间需要 5 分钟。

 

通常我们在读取文件的时候,会用到read(), readline(), readlines()。 通常可能会有这样的用法:

 

 

[python]   
 
  1. def test1():  
  2.     with open("/tmp/test.log", "r") as f:  
  3.         print f.read()  

或者

 

 

 

[python]   
 
  1. def test2():  
  2.     f = open("/tmp/test.log", "r")  
  3.     for line in f.readlines():  
  4.         print line  
  5.     f.close()  

 

read ()的方法是一次性把文件的内容以字符串的方式读到内存, 放到一个字符串变量中

 

readlines()的方法是一次性读取所有内容, 并按行生成一个list 

 

因为read()和readlines()是一次性把文件加载到内存, 如果文件较大, 甚至比内存的大小还大, 内存就会爆掉。 所以,这两种方法只适合读取小的文件。 

 

实际工作中,会碰到读取10几G的大文件的需求, 比如说日志文件。 这时候就要用的新的读取文件的方法。 这里提供两种方法, 有简单,有复杂,但基本原理都是一样的。 就是利用到生成器generator。 

 

方法一:

将文件切分成小段,每次处理完小段内容后,释放内存

这里会使用yield生成自定义可迭代对象, 即generator, 每一个带有yield的函数就是一个generator。 

 

 

[python]   
 
  1. def read_in_block(file_path):  
  2.     BLOCK_SIZE = 1024  
  3.     with open(file_path, "r") as f:  
  4.         while True:  
  5.             block = f.read(BLOCK_SIZE)  # 每次读取固定长度到内存缓冲区  
  6.             if block:  
  7.                 yield block  
  8.             else:  
  9.                 return  # 如果读取到文件末尾,则退出  
  10.   
  11.   
  12. def test3():  
  13.     file_path = "/tmp/test.log"  
  14.     for block in read_in_block(file_path):  
  15.         print block  

 

方法二:

利用open(“”, “”)系统自带方法生成的迭代对象

 

[python]   
 
  1. def test4():  
  2.     with open("/tmp/test.log") as f:  
  3.         for line in f:  
  4.             print line   

 

 

for line in f 这种用法是把文件对象f当作迭代对象, 系统将自动处理IO缓冲和内存管理, 这种方法是更加pythonic的方法。 比较简洁。 

 

 

以上代码均在python2.7环境调试通过。 

 

本文大略讲解了几种处理文件的方法, 并介绍了大文件的正确打开‘姿势’。 这里提到了几个概念: 分别是生成器,迭代器, 文件对象。 你可能会对这些概念比较陌生, 没关系, 我会在下篇再深入解释这些。 

 

转载请注明来自: http://blog.csdn/hackstoic/article/details/49804655 , 作者hackstoic

 

----------------------上篇完-------------------------------

 

【参考文献】

1.  http://chenqx.github.io/2014/10/29/-fastest-way-to-read-a-large-file/

2.  http://www.zhidaow.com/post/python-read-big-file

3.  http://pyzh.readthedocs.org/en/latest/the-python-yield-keyword-explained.html

4.  https://www.ibm.com/developerworks/cn/opensource/os-cn-python-yield/#ibm-pcon

 

转载于:https://www.cnblogs.com/june0507/p/7600969.html

你可能感兴趣的文章
CISCO 路由器(4)
查看>>
网络服务搭建、配置与管理大全(Linux版)
查看>>
Silverlight 5 Beta新特性[4]文本缩进控制
查看>>
springMVC多数据源使用 跨库跨连接
查看>>
Git服务端和客户端安装笔记
查看>>
Spring Security(14)——权限鉴定基础
查看>>
IntelliJ IDEA快捷键
查看>>
【iOS-cocos2d-X 游戏开发之十三】cocos2dx通过Jni调用Android的Java层代码(下)
查看>>
MongoDB的基础使用
查看>>
进程间通信——命名管道
查看>>
ssh登陆不需要密码
查看>>
ARP
查看>>
java mkdir()和mkdirs()区别
查看>>
桌面支持--excel自动换行
查看>>
虚拟化--003 vcac licence -成功案例
查看>>
windows server 2003各版本及2008各版本的最大识别内存大小
查看>>
OSChina 周六乱弹 ——揭秘后羿怎么死的
查看>>
IT人员的职业生涯规划
查看>>
sorry,you must have a tty to run sudo
查看>>
ios开发中使用正则表达式识别处理字符串中的URL
查看>>