Python进程池回调

进程池在进程 发生错误/正常结束时,回调

python 复制代码
import multiprocessing, time
from functools import partial

def worker(i):
    print(f"Worker process {i} started")
    if i == 5:
        raise Exception(f'{i} error occured(自定义异常)')
    time.sleep(5)  # 模拟一些工作

def call_back_with_args(unknown_args, p):
    print('call_back p:', p, unknown_args)

def error_callback(e):
    print('error_callback : ', type(e), e)

if __name__ == '__main__':
    with multiprocessing.Pool(processes=6) as pool:
        for i in range(6):
            pool.apply_async(worker, args=(i,),
                             callback=partial(call_back_with_args, p=i),
                             error_callback=error_callback)

        pool.close()  # 关闭进程池,不再接受新的任务
        # time.sleep(2)
        # pool.terminate()  # 停止进程池中的所有工作进程,但不等待它们完成
        pool.join()

partial科普

相关推荐
本地化文档3 分钟前
requests-docs-l10n
python·http·github·gitcode
Metaphor6924 分钟前
使用 Python 将 PowerPoint 转换为 PDF
python·pdf·powerpoint
XiYang-DING5 分钟前
【Java】Lambda表达式
java·开发语言·python
Irene19917 分钟前
配置 PyCharm(汉化版操作指南)
python·pycharm
来自远方的老作者7 分钟前
第9章 函数-9.7 函数嵌套
开发语言·python·函数·函数嵌套
7年前端辞职转AI8 分钟前
Python 错误和异常处理
python·编程语言
7年前端辞职转AI8 分钟前
Python 面向对象编程
python·编程语言
kishu_iOS&AI12 分钟前
机器学习 —— 总结
人工智能·python·机器学习·线性回归
API快乐传递者14 分钟前
Python 爬虫获取 1688 商品详情 API 接口实战指南
java·前端·python
疯狂成瘾者14 分钟前
LangChain Middleware 技术解析:从“插槽机制”到 Agent 运行时控制
数据库·python·langchain