python – 大型Pandas Dataframe并行处理
发布时间:2020-12-04 22:54:05 所属栏目:Python 来源:互联网
导读:我正在访问一个非常大的Pandas数据帧作为全局变量.通过 joblib并行访问此变量. 例如. df = db.query(select id, a_lot_of_data from table)def process(id): temp_df = df.loc[id] temp_df.apply(another_function)Parallel(n_jobs=8)
我正在访问一个非常大的Pandas数据帧作为全局变量.通过 joblib并行访问此变量. 例如. df = db.query("select id,a_lot_of_data from table") def process(id): temp_df = df.loc[id] temp_df.apply(another_function) Parallel(n_jobs=8)(delayed(process)(id) for id in df['id'].to_list()) 以这种方式访问原始df似乎是跨进程复制数据.这是意料之外的,因为原始df在任何子进程中都没有被改变? (或者是吗?) 解决方法对于joblib创建的每个进程,需要对整个DataFrame进行pickle和unpickled.在实践中,这非常慢并且还需要很多次的记忆.一种解决方案是使用表格格式将数据存储在HDF(df.to_hdf)中.然后,您可以使用select来选择数据子集以进行进一步处理.在实践中,这对于交互式使用来说太慢了.它也非常复杂,您的工作人员需要存储他们的工作,以便在最后一步中进行整合. 另一种方法是使用target =’parallel’探索numba.vectorize.这将需要使用NumPy数组而不是Pandas对象,因此它也有一些复杂性成本. 从长远来看,希望dask能够为熊猫带来并行执行,但这不是很快就会发生的事情. (编辑:百色站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- 对相关python进口的极限答案
- 在远程服务器上使用ein(emacs ipython notebook)
- python – 我应该使用GeoDjango来映射平面图吗?
- python – 近似大对称矩阵的最高3个特征值和特征
- python – 计算两个numpy数组之间相交值的有效方
- python – Django芹菜使用Ajax检索任务状态
- python – 来自Windows的OpenCV构建错误“RC对象
- 导入处理/模块从python2更改为python3?
- Django Rest Framework上的全文搜索仅支持MYSQL?
- python – ElementTree find()/ findall()找不到
热点阅读