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 Web框架Flask信号机制(signals)介绍
Jan 01 Python
使用Python内置的模块与函数进行不同进制的数的转换
Mar 12 Python
python+opencv实现动态物体追踪
Jan 09 Python
深入理解Python中的 __new__ 和 __init__及区别介绍
Sep 17 Python
Python OpenCV读取png图像转成jpg图像存储的方法
Oct 28 Python
详解Django+Uwsgi+Nginx 实现生产环境部署
Nov 06 Python
python 处理数字,把大于上限的数字置零实现方法
Jan 28 Python
python二进制文件的转译详解
Jul 03 Python
解决Django加载静态资源失败的问题
Jul 28 Python
Pytorch之view及view_as使用详解
Dec 31 Python
pycharm如何实现跨目录调用文件
Feb 28 Python
学习Python爬虫的几点建议
Aug 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
php 方便水印和缩略图的图形类
2009/05/21 PHP
php将fileterms函数返回的结果变成可读的形式
2011/04/21 PHP
ThinkPHP整合datatables实现服务端分页的示例代码
2018/02/10 PHP
jquery 常用操作整理 基础入门篇
2009/10/14 Javascript
JavaScript setTimeout和setInterval的使用方法 说明
2010/03/25 Javascript
修复ie8&chrome下window的resize事件多次执行
2011/10/20 Javascript
JQuery 操作/获取table具体代码
2013/06/13 Javascript
非常好用的JsonToString 方法 简单实例
2013/07/18 Javascript
使用jQuery实现的掷色子游戏动画效果
2014/03/14 Javascript
javascript检测是否联网的实现代码
2014/09/28 Javascript
jQuery动画与特效详解
2015/02/01 Javascript
jquery实现滑屏大图定时收缩为小banner图片的广告代码
2015/09/02 Javascript
直接拿来用的15个jQuery代码片段
2015/09/23 Javascript
详解JavaScript跨域总结与解决办法
2016/10/31 Javascript
Vue2递归组件实现树形菜单
2017/04/10 Javascript
利用forever和pm2部署node.js项目过程
2017/05/10 Javascript
利用node.js如何搭建一个简易的即时响应服务器
2017/05/28 Javascript
Angular中响应式表单的三种更新值方法详析
2017/08/22 Javascript
详解vue项目接入微信JSSDK的坑
2018/12/14 Javascript
vue实现随机验证码功能的实例代码
2019/04/30 Javascript
Flask框架学习笔记(一)安装篇(windows安装与centos安装)
2014/06/25 Python
简单介绍Python中的filter和lambda函数的使用
2015/04/07 Python
Python3.4学习笔记之类型判断,异常处理,终止程序操作小结
2019/03/01 Python
Python实现的矩阵转置与矩阵相乘运算示例
2019/03/26 Python
购买中国最好的电子产品:Geekbuying
2018/03/13 全球购物
在家更换处方镜片:Lensabl
2019/05/01 全球购物
优秀英语专业毕业生求职信
2013/11/23 职场文书
六月份红领巾广播稿
2014/02/03 职场文书
奥利奥广告词
2014/03/20 职场文书
揭牌仪式策划方案
2014/05/28 职场文书
电子商务专业毕业生求职信
2014/06/12 职场文书
学风建设演讲稿
2014/09/12 职场文书
学前班学生评语
2014/12/29 职场文书
劳资员岗位职责
2015/02/13 职场文书
2016年安全生产先进个人事迹材料
2016/02/29 职场文书
python套接字socket通信
2022/04/01 Python