python读取大文件越来越慢的原因与解决


Posted in Python onAugust 08, 2019

背景:

今天同事写代码,用python读取一个四五百兆的文件,然后做一串逻辑上很直观的处理。结果处理了一天还没有出来结果。问题出在哪里呢?

解决:

1. 同事打印了在不同时间点的时间,在需要的地方插入如下代码:

print time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))

发现一个规律,执行速度到后面时间越来越长,也就是处理速度越来越慢。

2. 为什么会越来越慢呢?

1)可能原因1,GC 的问题,有篇文章里面写,python list append 的时候会越来越慢,解决方案是禁止GC:

使用 gc.disable()和gc.enable()

 2)改完上面,仍然不行,然后看到一篇文章里面写,可能是因为 git 导致的,因为append 的时候 git 会不断同步,会出问题,于是删除 .git 文件夹,结果还是不行。

3)继续查询,发下一个及其有可能出问题的地方。dict 的 in dict.key(),判断 key 是否在 dict 里面,这个的效率是非常低的。看到一篇文章比较了效率:

          ① 使用  in dict.keys() 效率:

python读取大文件越来越慢的原因与解决

          ② 使用 has_key()  效率:

python读取大文件越来越慢的原因与解决

发现 has_key() 效率比较稳定。于是修改,问题解决。

后话:

最初的时候,的确是使用 has_key(), 结果后面上传代码的时候,公司代码检查过不了,提示不能使用这个函数,只能改成 in dict.key() 这种方式,为什么公司不让这么传呢?经过一番百度,发现原因所在:在 python3 中,直接将 has_key() 函数给删除了,所以禁止使用。那禁止了该怎么办呢?原来 python 中 in 很智能,能自动判断 key 是否在字典中存在。所以最正规的做法不是 has_key(),   更不是 in dict.keys(), 而是 in dict.  判断 key 在 map 中,千万别用 in dict.keys() !!!

附录:

in、 in dict.keys()、 has_key() 方法实战对比:

>>> a = {'name':"tom", 'age':10, 'Tel':110}
>>> a
{'age': 10, 'Tel': 110, 'name': 'tom'}
>>> print 'age' in a
True
>>> print 'age' in a.keys()
True
>>>
>>> print a.has_key("age")
True

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

参考资料:

Python 相关文章推荐
详解在Python程序中使用Cookie的教程
Apr 30 Python
python记录程序运行时间的三种方法
Jul 14 Python
Python开发SQLite3数据库相关操作详解【连接,查询,插入,更新,删除,关闭等】
Jul 27 Python
django如何实现视图重定向
Jul 24 Python
python-序列解包(对可迭代元素的快速取值方法)
Aug 24 Python
Python获取一个用户名的组ID过程解析
Sep 03 Python
Python实现二叉树的最小深度的两种方法
Sep 30 Python
在Python中使用K-Means聚类和PCA主成分分析进行图像压缩
Apr 10 Python
python基于Kivy写一个图形桌面时钟程序
Jan 28 Python
python - timeit 时间模块
Apr 06 Python
一文搞懂Python Sklearn库使用
Aug 23 Python
一行Python命令实现批量加水印
Apr 07 Python
Python实现Singleton模式的方式详解
Aug 08 #Python
Python判断字符串是否xx开始或结尾的示例
Aug 08 #Python
详解解决Python memory error的问题(四种解决方案)
Aug 08 #Python
Python学习笔记之迭代器和生成器用法实例详解
Aug 08 #Python
pandas 选取行和列数据的方法详解
Aug 08 #Python
pandas 对日期类型数据的处理方法详解
Aug 08 #Python
解决Python设置函数调用超时,进程卡住的问题
Aug 08 #Python
You might like
世界收音机发展史
2021/03/01 无线电
php一个找二层目录的小东东
2012/08/02 PHP
PHP面向对象学习笔记之一 基础概念
2012/10/06 PHP
解析PHP高效率写法(详解原因)
2013/06/20 PHP
Ajax+PHP快速上手及简单应用说明
2013/07/24 PHP
使用PHP curl模拟浏览器抓取网站信息
2013/10/28 PHP
dedecms中使用php语句指南
2014/11/13 PHP
PHP SOCKET编程详解
2015/05/22 PHP
配置Nginx+PHP的正确思路与过程
2016/05/10 PHP
Laravel 实现数据软删除功能
2019/08/21 PHP
How to Auto Include a Javascript File
2007/02/02 Javascript
JQuery的ajax基础上的超强GridView展示
2009/09/18 Javascript
JQuery实现的在新窗口打开链接的方法小结
2010/04/22 Javascript
Javascript 高阶函数使用介绍
2015/06/15 Javascript
js实现仿网易点击弹出提示同时背景变暗效果
2015/08/13 Javascript
javascript事件委托的用法及其好处简析
2016/04/04 Javascript
详解Node.js实现301、302重定向服务
2017/04/07 Javascript
Bootstrap响应式表格详解
2017/05/23 Javascript
Python读取图片为16进制表示简单代码
2018/01/19 Python
对python插入数据库和生成插入sql的示例讲解
2018/11/14 Python
基于pytorch中的Sequential用法说明
2020/06/24 Python
HTML5中Localstorage的使用教程
2015/07/09 HTML / CSS
英国在线自行车店:Merlin Cycles
2018/08/20 全球购物
医学专业本科毕业生自我鉴定
2013/12/28 职场文书
记者岗位职责
2014/01/06 职场文书
求职信的最佳写作思路
2014/02/01 职场文书
文明风采获奖感言
2014/02/18 职场文书
美国留学经济担保书
2014/05/20 职场文书
求职简历自荐信
2014/06/18 职场文书
文秘应届生求职信
2014/07/05 职场文书
新学期红领巾广播稿
2014/10/04 职场文书
六查六看自查报告
2014/10/14 职场文书
2015年元旦主持词开场白
2014/12/14 职场文书
研究生毕业登记表的自我鉴定范文
2019/07/15 职场文书
pandas中DataFrame重置索引的几种方法
2021/05/24 Python
使用Djongo模块在Django中使用MongoDB数据库
2021/06/20 Python