Python实现快速大文件比较代码解析


Posted in Python onSeptember 04, 2020

问题

假如,在有两个大文件分别存储了大量的数据,数据其实很简单就是一堆字符串,每行存储一条,如何快速筛选出两个文件的异同之处么,或者如何筛选出两个文件中不同的元素呢?

刚开始我是通过最简单的方法,利用for循环去一个个的判断,时间复杂度为m的n次幂,当然当文件数量级为十万或者百万时,速率简直慢到了极点。

解决方法

利用set()的different(方法)可快速比较,两个set集合的不同之处,也就是对集合进行数学运算

假设:数据1拥有858882条记录,数据2有360029条记录,快速挑选出数据2中而不存在与数据1中的数据

方法:先将两个文件中的数据读入两个list:data1和data2,然后通过:set(data2).difference(set(data1)),获取data2与data1的差集

下面为一个小的demo,可以看到近百万级的数据,比较出差集也就需要1秒左右,效率不是一般的高

import time
t1 = time.time()
data1 = []
for i in open("inDB.txt","r",encoding="utf-8"):
  i = i.strip("\n")
  i = i.lower()
  data1.append(i)
data2 = []
for i in open("data/18年.filename","r",encoding="utf-8"):
  i = i.strip("\n")
  i = i.lower()
  data2.append(i)
newdata = set(data2).difference(set(data1))
t2 = time.time()

print(f"data1 length:\t{len(data1)}")
print(f"data2 length:\t{len(data2)}")
print(f"newdata length:\t{len(newdata)}")
print(f"time use:\t{round(t2 - t1,3)}s")

Python实现快速大文件比较代码解析

list最多可以存放多少条数据呢?

python中list最多可以存放多少条数据呢?

对于这个问题,有个网友调研了python的文档,结果跟计算机的性能相关

64位机器:2^63-1=9223372036854775807
32位机器:2^31-1=2147483647
import sys
print(sys.maxsize)
print(pow(2,63)-1)
9223372036854775807
9223372036854775807

集合set的操作

内置函数 作用
add() 为集合添加元素
clear() 移除集合中的所有元素
copy() 拷贝一个集合
difference() 返回多个集合的差集
difference_update() 移除集合中的元素,该元素在指定的集合也存在。
discard() 删除集合中指定的元素
intersection() 返回集合的交集
intersection_update() 返回集合的交集。
isdisjoint() 判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。
issubset() 判断指定集合是否为该方法参数集合的子集。
issuperset() 判断该方法的参数集合是否为指定集合的子集
pop() 随机移除元素
remove() 移除指定元素
symmetric_difference() 返回两个集合中不重复的元素集合。
symmetric_difference_update() 移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。
union() 返回两个集合的并集
update() 给集合添加元素

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python中__call__方法示例分析
Oct 11 Python
详解在Python程序中自定义异常的方法
Oct 16 Python
Python2.7简单连接与操作MySQL的方法
Apr 27 Python
[原创]python爬虫(入门教程、视频教程)
Jan 08 Python
python中数据爬虫requests库使用方法详解
Feb 11 Python
Python使用Pickle库实现读写序列操作示例
Jun 15 Python
python和opencv实现抠图
Jul 18 Python
对Python random模块打乱数组顺序的实例讲解
Nov 08 Python
python+opencv实现摄像头调用的方法
Jun 22 Python
Python 使用 environs 库定义环境变量的方法
Feb 25 Python
Pycharm连接gitlab实现过程图解
Sep 01 Python
PySwarms(Python粒子群优化工具包)的使用:GlobalBestPSO例子解析
Apr 05 Python
基于python实现图片转字符画代码实例
Sep 04 #Python
Python HTMLTestRunner如何下载生成报告
Sep 04 #Python
详解python中的lambda与sorted函数
Sep 04 #Python
如何利用Python动态模拟太阳系运转
Sep 04 #Python
python装饰器三种装饰模式的简单分析
Sep 04 #Python
Django如何实现密码错误报错提醒
Sep 04 #Python
如何使用python socket模块实现简单的文件下载
Sep 04 #Python
You might like
全国FM电台频率大全 - 24 贵州省
2020/03/11 无线电
供参考的 php 学习提高路线分享
2011/10/23 PHP
yii操作session实例简介
2014/07/31 PHP
Wordpress ThickBox 添加“查看原图”效果代码
2010/12/11 Javascript
jquery鼠标停止移动事件
2013/12/21 Javascript
javascript对象的使用和属性操作示例详解
2014/03/02 Javascript
jQuery中even选择器的定义和用法
2014/12/23 Javascript
jQuery实现鼠标单击网页文字后在文本框显示的方法
2015/05/06 Javascript
js正则匹配出所有图片及图片地址src的方法
2015/06/08 Javascript
JS实现仿QQ面板的手风琴效果折叠菜单代码
2015/09/11 Javascript
JQuery标签页效果的两个实例讲解(4)
2015/09/17 Javascript
学习JavaScript正则表达式
2015/11/13 Javascript
Javascript实现通过选择周数显示开始日和结束日的实现代码
2016/05/30 Javascript
Bootstrap基本样式学习笔记之标签(5)
2016/12/07 Javascript
基于Marquee.js插件实现的跑马灯效果示例
2017/01/25 Javascript
微信小程序在地图选择地址并返回经纬度简单示例
2018/12/03 Javascript
vue实现的网易云音乐在线播放和下载功能案例
2019/02/18 Javascript
Node.js实现用户评论社区功能(体验前后端开发的乐趣)
2019/05/09 Javascript
JS中超越现实的匿名函数用法实例分析
2019/06/21 Javascript
layui table去掉右侧滑动条的实现方法
2019/09/05 Javascript
微信小程序实现打开并下载服务器上面的pdf文件到手机
2019/09/20 Javascript
Node.js path模块,获取文件后缀名操作
2020/11/07 Javascript
JavaScript函数柯里化实现原理及过程
2020/12/02 Javascript
Python作用域用法实例详解
2016/03/15 Python
浅谈Python 中整型对象的存储问题
2016/05/16 Python
Python:Scrapy框架中Item Pipeline组件使用详解
2017/12/27 Python
Django JWT Token RestfulAPI用户认证详解
2019/01/23 Python
opencv转换颜色空间更改图片背景
2019/08/20 Python
浙大毕业生自荐信
2014/01/26 职场文书
单位单身证明样本
2014/10/11 职场文书
2014年司机工作总结
2014/11/21 职场文书
重阳节慰问信
2015/02/15 职场文书
2015年大班保育员工作总结
2015/05/18 职场文书
人与自然的观后感
2015/06/18 职场文书
健康教育主题班会
2015/08/14 职场文书
Python利用Turtle绘制哆啦A梦和小猪佩奇
2022/04/04 Python