博客
关于我
Python读取大文件
阅读量:648 次
发布时间:2019-03-15

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

Python读取大文件的高效方法

当你试图用Python读取2GB或更大的文件时,使用普通的方法(如read和readlines)可能会抛出MemoryError,说明内存不足以加载整个文件。这通常发生在文件太大,无法完全读取时。

逐行读取方法

采用逐行读取的方式,可以有效减少内存占用。具体实现如下:

with open('filename.txt', 'r', encoding='utf-8') as f:    while True:        line = f.readline()        if not line:            break        print(line)

这种方法每次只读取一行内容,适合处理大文件。循环终止条件为文件结束。

指定长度读取方法

如果需要灵活控制读取长度,可以采用每次读取固定字节数的方式:

with open('filename.txt', 'r', encoding='utf-8') as f:    while True:        data = f.read(1024)        if not data:            break        print(data)

这种方式每次读取1024字节,从而分批处理大文件。

自动管理优化方法

更高效的方式是利用Python的内置文件处理功能,结合with语句和生成器。使用for循环遍历文件:

with open('filename.txt', 'r', encoding='utf-8') as f:    for line in f:        # 对每行内容进行处理        do_something(line)

这种方法利用了效率高的IO缓存机制,自动处理大文件,无需担心内存不足。

注意事项

  • 使用with语句来确保文件在错误或正常结束时被自动关闭。
  • 生成器方法for line in f自动管理内存,适合大文件处理,避免一次性读取过大文件内容。

通过以上方法,可以高效且安全地读取大文件,合理分配内存,避免内存错误。

转载地址:http://nmrlz.baihongyu.com/

你可能感兴趣的文章
NYOJ 737:石子合并(一)(区间dp)
查看>>
nyoj 91 阶乘之和(贪心)
查看>>
nyoj------203三国志
查看>>
NYOJ-525 一道水题
查看>>
nyoj58 最少步数
查看>>
N皇后问题
查看>>
OAuth 2.0 MAC Tokens
查看>>
OAuth 及 移动端鉴权调研
查看>>
OAuth2 + Gateway统一认证一步步实现(公司项目能直接使用),密码模式&授权码模式
查看>>
OAuth2 Provider 项目常见问题解决方案
查看>>
OAuth2 vs JWT,到底怎么选?
查看>>
Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
查看>>
oauth2-shiro 添加 redis 实现版本
查看>>
OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
查看>>
OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
查看>>
OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
查看>>
OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
查看>>
OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
查看>>
OAuth2.0_授权服务配置_三项内容_Spring Security OAuth2.0认证授权---springcloud工作笔记141
查看>>
OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
查看>>