python multiprocessing pool.map传递多个参数

转发:(15条消息) python multiprocessing pool.map传递多个参数_pool.map多个参数_兲行健的博客-CSDN博客

针对一些特殊需求,需要对map函数传递两个或者多个参数,这时单纯的map函数已经不能满足需求了,就需要借助偏函数来完成。

1.偏函数partial
偏函数是python自带的包,直接导入就能用。

偏函数partial的第一个参数就是所承载的原函数,之后原函数的参数再依次传入partial函数。

例子

复制代码
# -*- coding: utf-8 -*-
from functools import partial


def calsum(a, b):
    return a + b

# 承载calsum函数,并传入第一个参数
para = partial(calsum, 3)

# 传递第二个参数,就是把2传给para
res = para(2)

# 输出最后的结果
print(res)

# 5
复制代码

2.pool.map应用

举个例子说明:

首先先定义一个列表,里面存放着整数,之后计算这个列表的均值,用多进程判断列表里的每个数字与均值的大小,比均值大输出1,反之输出0.

复制代码
# -*- coding: utf-8 -*-
from multiprocessing import Pool
# 导入偏函数
from functools import partial
import numpy as np


def adjust(mean, number):
    if number > mean:
        return 1
    else:
        return 0


if __name__ == "__main__":
    num_list = [12, 45, 67, 88, 99, 62]
    # 计算均值
    num_mean = np.mean(num_list)
    # 定义进程池
    pool = Pool(4)
    # 定义偏函数,并传入均值
    pfunc = partial(adjust, num_mean)
    # 执行map,传入列表
    res_list = pool.map(pfunc, num_list)
    print(res_list)
复制代码

输出结果:

[0, 0, 1, 1, 1, 0]

 

posted @   burlingame  阅读(1310)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示