python多进程并发demo实例解析


Posted in Python onDecember 13, 2019

这篇文章主要介绍了python多进程并发demo实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

前言

下午需要简单处理一份数据,就直接随手写脚本处理了,但发现效率太低,速度太慢,就改成多进程了;

程序涉及计算、文件读写,鉴于计算内容挺多的,就用多进程了(计算密集)。

代码

import pandas as pd
from pathlib import Path
from concurrent.futures import ProcessPoolExecutor

parse_path = '/data1/v-gazh/CRSP/dsf_full_fields/parse'
source_path = '/data1/v-gazh/CRSP/dsf_full_fields/2th_split' # 目录中有3.3W个csv文件,串行的话,效率大打折扣


def parseData():
  source_path_list = list(Path(source_path).glob('*.csv'))
  multi_process = ProcessPoolExecutor(max_workers=20)
  multi_results = multi_process.map(func, source_path_list)


def func(p):
  source_p = str(p)
  parse_p = str(p).replace('2th_split', 'parse')
  df = pd.read_csv(source_p)
  df['date'] = pd.to_datetime(df['date'].astype(str)).dt.date
  df.sort_values(['date'], inplace=True)
  # 处理close为负的值(abs),添加status标识
  df['is_close'] = df['PRC'].map(lambda x: 0 if x < 0 or pd.isna(x) else 1)
  df['PRC'] = df['PRC'].abs()
  df.rename(columns={'CFACPR': 'factor'}, inplace=True)
  df['adj_low'] = df['BIDLO'] * df['factor']
  df['adj_high'] = df['ASKHI'] * df['factor']
  df['adj_close'] = df['PRC'] * df['factor']
  df['adj_open'] = df['OPENPRC'] * df['factor']
  df['adj_volume'] = df['VOL'] / df['factor']
  # calc change
  df['change'] = df['adj_close'].diff(1) / df['adj_close'].shift(1) df.drop_duplicates(inplace=True)
  df.to_csv(parse_p, index=False)
parseData()

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

Python 相关文章推荐
详解Python中列表和元祖的使用方法
Apr 25 Python
用Python程序抓取网页的HTML信息的一个小实例
May 02 Python
Python 字符串大小写转换的简单实例
Jan 21 Python
Python实现发送QQ邮件的封装
Jul 14 Python
详解PyTorch中Tensor的高阶操作
Aug 18 Python
python 有效的括号的实现代码示例
Nov 11 Python
Python:二维列表下标互换方式(矩阵转置)
Dec 02 Python
Python使用正则表达式实现爬虫数据抽取
Aug 17 Python
Pytest单元测试框架如何实现参数化
Sep 05 Python
详解python爬取弹幕与数据分析
Nov 14 Python
python实现图像高斯金字塔的示例代码
Dec 11 Python
Python代码风格与编程习惯重要吗?
Jun 03 Python
使用Matplotlib 绘制精美的数学图形例子
Dec 13 #Python
python plotly画柱状图代码实例
Dec 13 #Python
Pytorch实现的手写数字mnist识别功能完整示例
Dec 13 #Python
使用matplotlib绘制图例标签中带有公式的图
Dec 13 #Python
Python实现将蓝底照片转化为白底照片功能完整实例
Dec 13 #Python
python多进程重复加载的解决方式
Dec 13 #Python
使用pyqt5 tablewidget 单元格设置正则表达式
Dec 13 #Python
You might like
Laravel 5.0 发布 新版本特性详解
2015/02/10 PHP
利用Laravel生成Gravatar头像地址的优雅方法
2017/12/30 PHP
Laravel框架使用Redis的方法详解
2018/05/30 PHP
json的前台操作和后台操作实现代码
2012/01/20 Javascript
JS实现网页滚动条感应鼠标变色的方法
2015/02/26 Javascript
jQuery实现购物车计算价格功能的方法
2015/03/25 Javascript
javascript中call apply 的应用场景
2015/04/16 Javascript
JavaScript中错误正确处理方式小结你用对了吗
2017/10/10 Javascript
vue-cli之router基本使用方法详解
2017/10/17 Javascript
微信小程序利用canvas 绘制幸运大转盘功能
2018/07/06 Javascript
JavaScript 点击触发复制功能实例详解
2018/11/02 Javascript
JavaScript实现多文件下载方法解析
2020/08/07 Javascript
vue 使用微信jssdk,调用微信相册上传图片功能
2020/11/13 Javascript
[00:48]DOTA2国际邀请赛公开赛报名开始 扫码开启逐梦之旅
2018/06/06 DOTA
[03:48]大碗DOTA
2019/07/25 DOTA
python获取本机mac地址和ip地址的方法
2015/04/29 Python
Python3实现发送QQ邮件功能(文本)
2017/12/15 Python
python下解压缩zip文件并删除文件的实例
2018/04/24 Python
tensorflow实现简单的卷积网络
2018/05/24 Python
Python实现查询某个目录下修改时间最新的文件示例
2018/08/29 Python
Python数据类型之Number数字操作实例详解
2019/05/08 Python
在python中实现调用可执行文件.exe的3种方法
2019/07/07 Python
Python Django实现layui风格+django分页功能的例子
2019/08/29 Python
PyQt中使用QtSql连接MySql数据库的方法
2020/07/28 Python
Python如何截图保存的三种方法(小结)
2020/09/01 Python
html5使用Drag事件编辑器拖拽上传图片的示例代码
2017/08/22 HTML / CSS
英国最大的宝石首饰超市:QP Jewellers
2018/09/23 全球购物
澳大利亚在线家具店:Luxo Living
2019/03/24 全球购物
Lookfantastic美国/加拿大:英国知名美妆购物网站
2019/03/27 全球购物
餐厅筹备计划书
2014/04/25 职场文书
群众路线党员个人剖析材料
2014/10/08 职场文书
分居协议书范本(律师见证版)
2014/11/26 职场文书
部队2014年终工作总结
2014/11/27 职场文书
高中生物教学反思
2016/02/20 职场文书
读《皮囊》有感:理解是对他人的最大的善举
2019/11/14 职场文书
电频谱管理的原则是什么
2022/02/18 无线电