(数据科学学习手札86)全平台支持的pandas运算加速神器
本文示例代码已上传至我的
Github
仓库https://github.com/CNFeffery/DataScienceStudyNotes
1 简介
随着其功能的不断优化与扩充,pandas
已然成为数据分析领域最受欢迎的工具之一,但其仍然有着一个不容忽视的短板——难以快速处理大型数据集,这是由于pandas
中的工作流往往是建立在单进程的基础上,使得其只能利用单个处理器核心来实现各种计算操作,这就使得pandas
在处理百万级、千万级甚至更大数据量时,出现了明显的性能瓶颈。
本文要介绍的工具modin
就是一个致力于在改变代码量最少的前提下,调用起多核计算资源,对pandas
的计算过程进行并行化改造的Python
库,并且随着其近期的一系列内容更新,modin
基于Dask
开始对Windows
系统同样进行了支持,使得我们只需要改变一行代码,就可以在所有平台上获得部分pandas
功能可观的计算效率提升。
图1
2 基于modin的pandas运算加速
modin
支持Windows
、Linux
以及Mac
系统,其中Linux
与Mac
平台版本的modin
工作时可基于并行运算框架Ray
和Dask
,而Windows
平台版本目前只支持Dask
作为计算后端(因为Ray
没有Win
版本),安装起来十分方便,可以用如下3种命令来安装具有不同后端的modin
:
pip install modin[dask] # 安装dask后端
pip install modin[ray] # 安装ray后端(windows不支持)
pip install modin[all] # 推荐方式,自动安装当前系统支持的所有后端
本文在Win10
系统上演示modin
的功能,执行命令:
pip install modin[all]
成功安装modin
+dask
之后,在使用modin
时,只需要将我们习惯的import pandas as pd
变更为import modin.pandas as pd
即可,接下来我们来看一下在一些常见功能上,pandas
VSmodin
性能差异情况,首先我们分别使用pandas
和modin
读入一个大小为1.1G的csv
文件esea_master_dmg_demos.part1.csv
,来自kaggle
(https://www.kaggle.com/skihikingkevin/csgo-matchmaking-damage/data),记录了关于热门游戏CS:GO
的一些玩家行为数据,因为体积过大,请感兴趣的读者朋友自行去下载:
图2
为了区分他们,在导入时暂时将modin.pandas
命名为mpd
:
图3
可以看到因为是Win
平台,所以使用的计算后端为Dask
,首先我们来分别读入文件查看耗时:
图4
借助jupyter notebook
记录计算时间的插件,可以看到原生的pandas
耗时14.8秒,而modin
只用了5.32秒,接着我们再来试试concat
操作:
图5
可以看到在pandas
花了8.78秒才完成任务的情况下,modin
仅用了0.174秒,取得了惊人的效率提升。接下来我们再来执行常见的检查每列缺失情况的任务:
图6
这时耗时差距虽然不如concat
操作时那么巨大,也是比较可观的,但是modin
毕竟是一个处理快速开发迭代阶段的工具,其针对pandas
的并行化改造尚未覆盖全部的功能,譬如分组聚合功能。对于这部分功能,modin
会在执行代码时检查自己是否支持,对于尚未支持的功能modin
会自动切换到pandas
单核后端来执行运算,但由于modin
中组织数据的形式与pandas
不相同,所以中间需要经历转换:
图7
这种时候modin
的运算反而会比pandas
慢很多:
图8
因此我对modin
持有的态度是在处理大型数据集时,部分应用场景可以用其替换pandas
,即其已经完成可靠并行化改造的pandas
功能,你可以在官网对应界面(https://modin.readthedocs.io/en/latest/supported_apis/index.html )查看其已经支持及尚未良好支持的功能,,因为modin
还处于快速开发阶段,很多目前无法支持的功能也许未来不久就会被加入modin
:
图9
以上就是本文的全部内容,如有疑问欢迎在评论区与我讨论。
(数据科学学习手札86)全平台支持的pandas运算加速神器的更多相关文章
- (数据科学学习手札72)用pdpipe搭建pandas数据分析流水线
1 简介 在数据分析任务中,从原始数据读入,到最后分析结果出炉,中间绝大部分时间都是在对数据进行一步又一步的加工规整,以流水线(pipeline)的方式完成此过程更有利于梳理分析脉络,也更有利于查错改 ...
- (数据科学学习手札134)pyjanitor:为pandas补充更多功能
本文示例代码及文件已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 pandas发展了如此多年,所包含的功能已 ...
- (数据科学学习手札50)基于Python的网络数据采集-selenium篇(上)
一.简介 接着几个月之前的(数据科学学习手札31)基于Python的网络数据采集(初级篇),在那篇文章中,我们介绍了关于网络爬虫的基础知识(基本的请求库,基本的解析库,CSS,正则表达式等),在那篇文 ...
- (数据科学学习手札44)在Keras中训练多层感知机
一.简介 Keras是有着自主的一套前端控制语法,后端基于tensorflow和theano的深度学习框架,因为其搭建神经网络简单快捷明了的语法风格,可以帮助使用者更快捷的搭建自己的神经网络,堪称深度 ...
- (数据科学学习手札40)tensorflow实现LSTM时间序列预测
一.简介 上一篇中我们较为详细地铺垫了关于RNN及其变种LSTM的一些基本知识,也提到了LSTM在时间序列预测上优越的性能,本篇就将对如何利用tensorflow,在实际时间序列预测任务中搭建模型来完 ...
- (数据科学学习手札32)Python中re模块的详细介绍
一.简介 关于正则表达式,我在前一篇(数据科学学习手札31)中已经做了详细介绍,本篇将对Python中自带模块re的常用功能进行总结: re作为Python中专为正则表达式相关功能做出支持的模块,提供 ...
- (数据科学学习手札69)详解pandas中的map、apply、applymap、groupby、agg
*从本篇开始所有文章的数据和代码都已上传至我的github仓库:https://github.com/CNFeffery/DataScienceStudyNotes 一.简介 pandas提供了很多方 ...
- (数据科学学习手札75)基于geopandas的空间数据分析——坐标参考系篇
本文对应代码已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 在上一篇文章中我们对geopandas中的数据结 ...
- (数据科学学习手札55)利用ggthemr来美化ggplot2图像
一.简介 R中的ggplot2是一个非常强大灵活的数据可视化包,熟悉其绘图规则后便可以自由地生成各种可视化图像,但其默认的色彩和样式在很多时候难免有些过于朴素,本文将要介绍的ggthemr包专门针对原 ...
随机推荐
- Spring处理@Configuration的分析
Spring处理@Configuration的分析 声明:本文若有任何纰漏.错误,还请不吝指出! 序言 @Configuration注解在SpringBoot中作用很大,且不说SpringBoot中的 ...
- 迟早要知道的JS系列之常用数组方法
常用数组方法 一.不会改变原始数组的方法: 即访问方法,下面的这些方法绝对不会改变调用它们的对象的值,只会返回一个新的数组或者返回一个其它的期望值. 1. concat() ** 语法:** Java ...
- html5做webAPP界面适配总结
一.px em rem px像素(Pixel).相对长度单位.像素px是相对于显示器屏幕分辨率而言的. em是相对长度单位.相对于当前对象内文本的字体尺寸.如当前对行内文本的字体尺寸未被人为设置,则相 ...
- Flow Control
Exercise-01 Max Of Two Numbers Write a function that takes two numbers and returns the maximum of th ...
- 一次 nginx 返回 302 问题解决
1.问题描述: 应用服务器通过post方式向nginx服务器发送http请求,返回 302 2.问题解决过程 2.1.查询nginx日志,开始以为302错误会在nginx的错误日志error.log, ...
- PHP 数据库操作函数笔记
/建立 或者 关闭mysql服务器 @符号用于屏蔽错误信息 $link=@mysqli_connect('127.0.0.1','root','123456','php1',3306); if(mys ...
- [Python基础]007.字符串
字符串 内建操作 字符串长度 大小写变换 去空格或其他 连接字符串 查找替换 分割 判断 内建操作 字符串长度 len 代码 s = 'abcd' print len(s) 大小写变换 lower 小 ...
- gopher 协议初探
Gopher 协议初探 最近两天看到了字节脉搏实验室公众号上有一篇<Gopher协议与redis未授权访问>的文章,其中对gopher协议进行了比较详细的介绍,所以打算跟着后面复现学习一下 ...
- Java中的String、StringBuffer和StringBuilder
作为作为一个已经入了门的java程序猿,肯定对Java中的String.StringBuffer和StringBuilder都略有耳闻了,尤其是String 肯定是经常用的.但肯定你有一点很好奇,为什 ...
- 【Spring】JdbcTemplate的使用,查询,增、删、改
数据库名:taobaodb 配置文件: JdbcTemplate主要提供以下五类方法: execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句: update方法及batchUpdat ...