我使用python的multiprocessing.Pool
模块进行多处理,但是得到TypeError: list indices must be integers, not str
错误:
这是我的代码:
def getData(qid):
r = requests.get("http://api.xxx.com/api?qid=" + qid)
if r.status == 200:
DBC.save(json.loads(r.text))
def getAnotherData(qid):
r = requests.get("http://api.xxxx.com/anotherapi?qid=" + qid)
if r.status == 200:
DBC.save(json.loads(r.text))
def getAllData(qid):
print qid
getData(str(qid))
getAnotherData(str(qid))
if __name__ == "__main__":
pool = Pool(processes=200)
pool.map(getAllData, range(10000, 700000))
运行代码一段时间后(不是立即),将抛出异常
^{pr2}$怎么了?它是Pool
模块的错误吗?在
当工作任务引发异常时,
Pool
会捕捉到异常,将其发送回父进程,并重新对异常进行评级,但这并不能保留原始的回溯(因此,您只需看到它在父进程中重读的位置,这并不是很有帮助)。猜测一下,DBC.save
中的某个东西期望从JSON加载的值是int
,实际上是str
。在如果您想看到真正的回溯,
import traceback
在顶层,并将worker函数的顶层更改为:所以你可以在工作者身上看到真正的回溯,而不仅仅是在父母身上绝育的、几乎毫无用处的回溯。在
相关问题 更多 >
编程相关推荐