Python多进程操作Coding

本文通过Python代码示例介绍如何使用多进程池进行任务并行处理。具体包括创建进程池、分配任务、获取结果等步骤,并展示了如何通过回调函数收集各进程的执行结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import time
import multiprocessing

ls = [i for i in range(10000)]

print(ls)

ls1 = ls[0: 100]

ls2 = ls[100:200]
ls3 = ls[200: 300]
l = []

test2调用test1函数

def test2():
test1()
print(‘test2’)

def func1(x):
for i in ls1:
l.append(i)
# print(‘func1’)
# print(l)
return l

def func2(x):
for i in ls2:
l.append(i)
# print(‘func2’)
# print(l)
return l

def func3(x):
for i in ls3:
l.append(i)
print(‘func3’)
# print(l)
return l

if name == “main“:

def test1():
    print('test1')
    start_time = time.clock()
    pool = multiprocessing.Pool(processes=3)
    res1 = pool.apply_async(func1, (1, ), callback=func1)
    res2 = pool.apply_async(func2, (2, ), callback=func2)
    res3 = pool.apply_async(func3, (3, ), callback=func3)
    pool.close()
    pool.join()
    print('-------------------------')
    # l = res3.get()
    # print(l)
    l1 = res1.get()
    l2 = res2.get()
    l3 = res3.get()
    # print(l1)
    # print(l2)
    print(l3)
    print("Sub-process(es) done.")
    end_time = time.clock()
    run_time = end_time - start_time
    print(run_time)

test2()
# print('-------------l1-------------------')
# print(l1)
# print('-------------l2-------------------')
# print(l2)
# print('-------------l3-------------------')
# print(l3)
#
# print('-------------l-------------------')
# l = l1 + l2 + l3
# print(l)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值