gpt4 book ai didi

python - Python 中的动态过程

转载 作者:太空狗 更新时间:2023-10-30 00:15:40 24 4
gpt4 key购买 nike

我有一个关于 Python 多处理的问题。我正在尝试获取一个数据集,分成 block ,然后将这些 block 传递给并发运行的进程。我需要使用简单的计算来转换大型数据表(例如,电阻 -> 热敏电阻的温度)。

下面列出的代码几乎可以按预期工作,但它似乎没有产生任何新进程(或者如果是的话,一次只产生一个)。

from multiprocessing import Process

class Worker(Process):
# example data transform
def process(self, x): return (x * 2) / 3

def __init__(self, list):
self.data = list
self.result = map(self.process, self.data)
super(Worker, self).__init__()

if __name__ == '__main__':
start = datetime.datetime.now()
dataset = range(10000) # null dataset
processes = 3

for i in range(processes):
chunk = int(math.floor(len(dataset) / float(processes)))

if i + 1 == processes:
remainder = len(dataset) % processes
else: remainder = 0

tmp = dataset[i * chunk : (i + 1) * chunk + remainder]
exec('worker'+str(i)+' = Worker(tmp)')
exec('worker'+str(i)+'.start()')

for i in range(processes):
exec('worker'+str(i)+'.join()')
# just a placeholder to make sure the initial values of the set are as expected
exec('print worker'+str(i)+'.result[0]')

最佳答案

无需向每个进程发送 block 数,只需使用 get_nowait() 并处理最终的 Queue.Empty 异常。每个进程将获得不同数量的 CPU 时间,这应该使它们都处于忙碌状态。

import multiprocessing, Queue

class Worker(multiprocessing.Process):
def process(self, x):
for i in range(15):
x += (float(i) / 2.6)
return x

def __init__(self, input, output):
self.input = input
self.output = output
super(Worker, self).__init__()

def run(self):
try:
while True:
self.output.put(self.process(self.input.get_nowait()))
except Queue.Empty:
pass


if name == 'main':
dataset = range(10)
processes = multiprocessing.cpu_count()
input = multiprocessing.Queue()
output = multiprocessing.Queue()

for obj in dataset:
input.put(obj)
for i in range(processes):
Worker(input, output).start()

for i in range(len(dataset)):
print output.get()

关于python - Python 中的动态过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/740717/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com