Я искал здесь о том, как сделать работу с потоками в Python, но я так и не смог получить ответ, который мне нужен. Я не очень знаком с классами Python Queue и Threading, и поэтому некоторые ответы, представленные здесь, не имеют никакого смысла для меня.
Я хочу создать пул потоков, которым я могу дать разные задачи, и когда все они закончатся, получим значения результата и обработаем их. До сих пор я пытался сделать это, но я не смог получить результаты. Код, который я написал:
from threading import Thread
from Queue import Queue
class Worker(Thread):
    """Thread executing tasks from a given tasks queue"""
    def __init__(self, tasks):
        Thread.__init__(self)
        self.tasks = tasks
        self.daemon = True
        self.result = None
        self.start()
    def run(self):
        while True:
            func, args, kargs = self.tasks.get()
            try:
                self.result = func(*args, **kargs)
            except Exception, e:
                print e
            self.tasks.task_done()
    def get_result(self):
        return self.result
class ThreadPool:
    """Pool of threads consuming tasks from a queue"""
    def __init__(self, num_threads):
        self.tasks = Queue(num_threads)
        self.results = []
        for _ in range(num_threads):
            w = Worker(self.tasks)
            self.results.append(w.get_result())
    def add_task(self, func, *args, **kargs):
        """Add a task to the queue"""
        self.tasks.put((func, args, kargs))
    def wait_completion(self):
        """Wait for completion of all the tasks in the queue"""
        self.tasks.join()
    def get_results(self):
        return self.results
def foo(word, number):
    print word*number
    return number
words = ['hello', 'world', 'test', 'word', 'another test']
numbers = [1,2,3,4,5]
pool = ThreadPool(5)
for i in range(0, len(words)):
    pool.add_task(foo, words[i], numbers[i])
pool.wait_completion()
results = pool.get_results()
print results
Выходные данные выводят строки с заданным словом, умноженным на указанное число, но список результатов полон значениями None, поэтому я должен поместить возвращаемые значения функции.
Или проще - создать список, в котором я заполняю очередь и добавляю словарь или некоторую переменную для сохранения результата в качестве аргумента моей функции, а после добавления задачи в очередь добавляю этот аргумент результата в список результатов. :
def foo(word, number, r):
    print word*number
    r[(word,number)] = number
    return number
words = ['hello', 'world', 'test', 'word', 'another test']
numbers = [1,2,3,4,5]
pool = ThreadPool(5)
results = []
for i in range(0, len(words)):
    r = {}
    pool.add_task(foo, words[i], numbers[i], r)
    results.append(r)
print results
