如何将队列字典传递给multiprocessing.Process

时间:2015-11-24 13:22:18

标签: python python-multiprocessing

我不确定是否可以将队列字典作为参数传递给进程。如果它只能作为kwargs,那怎么办呢?

from multiprocessing import Process, Queue


class WordsManager:

    def __init__(self, my_dict):
        self.dict = my_dict

    def run(self):
        pass


def words_worker(my_dict):
    worker = WordsManager(my_dict)
    worker.run()


def start_job_manager():
    my_dict = {}
    for language in ('en', 'de', 'es'):
        my_dict[language] = Queue()

    words_manager = {'process': None, 'my_dict': my_dict}
    words_manager["process"] = Process(target=words_worker, args=(words_manager['my_dict']))
    words_manager["process"].daemon = True
    words_manager["process"].start()

    return words_manager


start_job_manager()

错误是:

Process Process-4:
Traceback (most recent call last):
   File "/home/antonio/python/lib/python3.4/multiprocessing/process.py", line 254, in _bootstrap
self.run()
  File "/home/antonio/python/lib/python3.4/multiprocessing/process.py", line 93, in run
self._target(*self._args, **self._kwargs)
TypeError: words_worker() takes 1 positional argument but 3 were given

2 个答案:

答案 0 :(得分:1)

问题在于您传递给流程的参数:

args=(words_manager['my_dict'])

大括号不会被解释为元组,因此您不会将一系列参数传递给args。相反,您应该通过在末尾放置,来显式创建1元素元组:

args=(words_manager['my_dict'],)

来自Python Docs

  

一个特殊的问题是构造包含0或1个项目的元组:语法有一些额外的怪癖来适应这些。空元组由一对空括号构成;通过使用逗号跟随值来构造具有一个项目的元组(仅在括号中包含单个值是不够的)。丑陋但有效。

答案 1 :(得分:0)

如果我在元素后面使用逗号,它会正常运行

args=(words_manager['my_dict'],)

我认为没有逗号,Python会将字典中的每个值解释为参数,但是使用逗号将其视为一个元组,其中words_manager [' my_dict']作为唯一参数。