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实现将pvr格式转换成pvr.ccz的方法
Apr 28 Python
python在控制台输出进度条的方法
Jun 20 Python
python删除特定文件的方法
Jul 30 Python
深入理解 Python 中的多线程 新手必看
Nov 20 Python
Python字符串格式化%s%d%f详解
Feb 02 Python
Python利用openpyxl库遍历Sheet的实例
May 03 Python
pytorch + visdom CNN处理自建图片数据集的方法
Jun 04 Python
pytorch使用Variable实现线性回归
May 21 Python
对pyqt5中QTabWidget的相关操作详解
Jun 21 Python
Python算法中的时间复杂度问题
Nov 19 Python
Python解释器以及PyCharm的安装教程图文详解
Feb 26 Python
利用Python将list列表写入文件并读取的方法汇总
Mar 25 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
PHP常用代码大全(新手入门必备)
2010/06/29 PHP
php截取后台登陆密码的代码
2012/05/05 PHP
php文件操作实例代码
2012/05/10 PHP
微信公众平台DEMO(PHP)
2016/05/04 PHP
PHP生成及获取JSON文件的方法
2016/08/23 PHP
如何在Laravel5.8中正确地应用Repository设计模式
2019/11/26 PHP
Ext javascript建立超链接,进行事件处理的实现方法
2009/03/22 Javascript
利用javascript实现web页面中指定区域打印
2013/10/30 Javascript
connect中间件session、cookie的使用方法分享
2014/06/17 Javascript
Linux下使用jq友好的打印JSON技巧分享
2014/11/18 Javascript
在JavaScript中处理时间之getHours()方法的使用
2015/06/10 Javascript
javascript高级编程之函数表达式 递归和闭包函数
2015/11/29 Javascript
angularjs表格分页功能详解
2016/01/21 Javascript
基于BootStarp的Dailog
2016/04/28 Javascript
jquery自定义显示消息数量
2017/12/19 jQuery
vue中实现在外部调用methods的方法(推荐)
2018/02/08 Javascript
微信小程序日历效果
2018/12/29 Javascript
Python 返回汉字的汉语拼音
2009/02/27 Python
介绍Python中几个常用的类方法
2015/04/08 Python
Python isinstance函数介绍
2015/04/14 Python
python使用multiprocessing模块实现带回调函数的异步调用方法
2015/04/18 Python
Python装饰器用法实例总结
2018/02/07 Python
python实现批量图片格式转换
2020/06/16 Python
使用python实现unix2dos和dos2unix命令的例子
2019/08/13 Python
Python模块_PyLibTiff读取tif文件的实例
2020/01/13 Python
Django自定义全局403、404、500错误页面的示例代码
2020/03/08 Python
解决echarts中饼图标签重叠的问题
2020/05/16 Python
python调用私有属性的方法总结
2020/07/24 Python
selenium切换标签页解决get超时问题的完整代码
2020/08/30 Python
Python实例教程之检索输出月份日历表
2020/12/16 Python
Canvas 文字碰撞检测并抽稀的方法
2019/05/27 HTML / CSS
联想墨西哥官方网站:Lenovo墨西哥
2016/08/17 全球购物
德国综合购物网站:OTTO
2018/11/13 全球购物
文员的职业生涯规划发展方向
2014/02/08 职场文书
政风行风整改方案
2014/10/25 职场文书
故意伤害罪辩护词
2015/05/21 职场文书