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里将list中元素依次向前移动一位
Sep 12 Python
Python中os.path用法分析
Jan 15 Python
Python自动登录126邮箱的方法
Jul 10 Python
深入理解Python中变量赋值的问题
Jan 12 Python
对python中不同模块(函数、类、变量)的调用详解
Jul 16 Python
在python中实现同行输入/接收多个数据的示例
Jul 20 Python
Python中的 sort 和 sorted的用法与区别
Aug 10 Python
Python全局锁中如何合理运用多线程(多进程)
Nov 06 Python
python 利用turtle库绘制笑脸和哭脸的例子
Nov 23 Python
python操作cfg配置文件方式
Dec 22 Python
Python requests模块cookie实例解析
Apr 14 Python
python实现npy格式文件转换为txt文件操作
Jul 01 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 Zip压缩 在线对文件进行压缩的函数
2010/05/26 PHP
ThinkPHP上使用多说评论插件的方法
2014/10/31 PHP
对PHP依赖注入的理解实例分析
2016/10/09 PHP
Laravel统计一段时间间隔的数据方法
2019/10/09 PHP
jQuery插件 tabBox实现代码
2010/02/09 Javascript
javascript对象之内置对象Math使用方法
2010/04/16 Javascript
如何使用jquery动态加载js,css文件实现代码
2013/04/03 Javascript
jQuery .attr()和.removeAttr()方法操作元素属性示例
2013/07/16 Javascript
纯js代码实现未知宽高的元素在指定元素中垂直水平居中显示
2015/09/12 Javascript
Jquery实现select multiple左右添加和删除功能的简单实例
2016/05/26 Javascript
jQuery点击头像上传并预览图片
2017/02/23 Javascript
AngularJS表单验证功能分析
2017/05/26 Javascript
python批量同步web服务器代码核心程序
2014/09/01 Python
Python列表计数及插入实例
2014/12/17 Python
python单例模式实例分析
2015/04/08 Python
Django基于ORM操作数据库的方法详解
2018/03/27 Python
Python统计单词出现的次数
2018/04/04 Python
python读取csv文件并把文件放入一个list中的实例讲解
2018/04/27 Python
django 多数据库配置教程
2018/05/30 Python
python使用tornado实现简单爬虫
2018/07/28 Python
django自定义模板标签过程解析
2019/12/14 Python
Django异步任务线程池实现原理
2019/12/17 Python
基于Python模拟浏览器发送http请求
2020/11/06 Python
sklearn中的交叉验证的实现(Cross-Validation)
2021/02/22 Python
Html5实现iPhone开机界面示例代码
2013/06/30 HTML / CSS
俄语地区最大的中国商品在线购物网站之一:Umka Mall
2019/11/03 全球购物
英国领先的餐饮折扣俱乐部:Gourmet Society
2020/07/26 全球购物
几道数据库的概念性面试题
2014/05/30 面试题
求职毕业生自荐书
2014/02/08 职场文书
教师党员整改措施
2014/10/24 职场文书
班主任经验交流材料
2014/12/16 职场文书
书法社团活动总结
2015/05/07 职场文书
同乡会致辞
2015/07/30 职场文书
JavaScript继承的三种方法实例
2021/05/12 Javascript
CKAD认证中部署k8s并配置Calico插件
2022/03/31 Servers
Python可视化神器pyecharts绘制地理图表
2022/07/07 Python