python - 类型错误 : 'tuple' object is not callable while calling multiprocessing in python

标签 python python-multiprocessing

我正在尝试使用多处理和队列执行以下脚本,

from googlefinance import getQuotes
from yahoo_finance import Share
import multiprocessing


class Stock:

    def __init__(self,symbol,q):
        self.symbol = symbol
        self.q = q

    def current_value(self):
        current_price =self.q.put(float(getQuotes(self.symbol)[0]['LastTradeWithCurrency']))
        return current_price

    def fundems(self):

        marketcap = self.q.put(Share(self.symbol).get_market_cap())
        bookvalue = self.q.put(Share(self.symbol).get_book_value())
        dividend = self.q.put(Share(self.symbol).get_dividend_share())
        dividend_paydate = self.q.put(Share(self.symbol).get_dividend_pay_date())
        dividend_yield = self.q.put(Share(self.symbol).get_dividend_yield())

        return marketcap, bookvalue, dividend, dividend_paydate, dividend_yield



def main():
    q = multiprocessing.Queue()
    Stock1 = Stock('aapl', q) 


    p1 = multiprocessing.Process(target = Stock1.current_value(), args = (q,))
    p2 = multiprocessing.Process(target = Stock1.fundems(), args = (q,))
    p1.start()
    p2.start()
    p1.join()
    p2.join()

    while q.empty() is False:
        print q.get()


if __name__ == '__main__':
    main()

我得到的输出如下:

Process Process-2:
Traceback (most recent call last):
  File "/usr/lib/python2.7/multiprocessing/process.py", line 258, in _bootstrap
    self.run()
  File "/usr/lib/python2.7/multiprocessing/process.py", line 114, in run
    self._target(*self._args, **self._kwargs)
TypeError: 'tuple' object is not callable
139.52
732.00B
25.19
2.28
2/16/2017
1.63

在这里我看到我能够得到我想要的输出,但是之前有一个错误,这让我很困惑。

任何人都可以帮我理解这里的概念吗?

提前致谢。

最佳答案

目标应该是一个未调用的函数,您正在父进程中调用该函数,并尝试启动一个进程,并将调用结果作为目标。变化:

p1 = multiprocessing.Process(target = Stock1.current_value(), args = (q,))
p2 = multiprocessing.Process(target = Stock1.fundems(), args = (q,))

至:

p1 = multiprocessing.Process(target=Stock1.current_value)
p2 = multiprocessing.Process(target=Stock1.fundems)

q 作为参数被删除,因为该对象是用 q 构造的,并使用它自己的状态来访问它,它不会将其作为参数接收每种方法。

关于python - 类型错误 : 'tuple' object is not callable while calling multiprocessing in python,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42662215/

相关文章:

python - 从 pickle 文件加载 multiprocessing.manager.dictionary 时出错

python - 如何使用 python 多处理模块重新启动进程

python - 循环中的多处理, "Pool not running"错误

python - 在内存中压缩/压缩 numpy 数组

python - 如何将字典插入空字典?

重启 celery worker 的 Python Celery 任务

python - 列表中的 Numpy 掩码

python - 如何在 Python 中使用多处理时解决 BrokenPipeError

python - python中for行的语法错误

python - 如何在 Python Web 机器人中有效地实现多线程/多处理?