首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >多进程Python 3

多进程Python 3
EN

Stack Overflow用户
提问于 2015-10-16 12:41:46
回答 1查看 1.3K关注 0票数 0

我有一个遍历数字数组的脚本,这些数字被传递给一个调用API的函数。它返回JSON数据,然后将这些数据写入CSV。

代码语言:javascript
复制
for label_number in label_array:
    call_api(domain, api_call_1, api_call_2, label_number, api_key)

这个列表最多可以有7000个元素,因为API需要几秒钟的时间来响应,这可能需要几个小时来运行整个脚本。多处理似乎是与之相适应的方式。我不太清楚如何使用上面的循环来做到这一点。我正在查看的文档是

https://docs.python.org/3.5/library/multiprocessing.html

我在网上找到一篇类似的文章

Python Multiprocessing a for loop

但是操纵它似乎不起作用,我认为我在将所有变量传递给函数时搞砸了。

任何帮助都将不胜感激。

EN

回答 1

Stack Overflow用户

发布于 2015-10-16 16:20:08

多处理可能会有所帮助,但这听起来更像是一个线程问题。任何IO实现都应该是异步的,这就是线程的作用。更好的是,在python3.4以后的版本中,您可以使用asynciohttps://docs.python.org/3.4/library/asyncio.html

如果你有python3.5,这将会很有用:https://docs.python.org/3.5/library/asyncio-task.html#example-hello-world-coroutine

您可以将asynciomultiprocessing混合使用,以获得优化的结果。此外,我还使用了joblib

代码语言:javascript
复制
import multiprocessing
from joblib import Parallel, delayed 

def parallelProcess(i):
    for index, label_number in enumerate(label_array):
        if index % i == 0:
            call_api_async(domain, api_call_1, api_call_2, label_number, api_key)

if __name__=="__main__":
    num_cores_to_use = multiprocessing.cpu_count()
    inputs = range(num_cores_to_use)
    Parallel(n_jobs=num_cores_to_use)(delayed(parallelProcess)(i) for i in inputs)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33162690

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档