文章详情页
python 加快程序运行问题
浏览:152日期:2022-07-26 13:50:42
问题描述
假设:
def get(url): #这里是get请求 return urlfor i in urls: get(i)#这里采用循环去调用请求#这样速度好像比较慢,有什么方法可以#当多个请求时,也可以快速完成程序
谢谢了
问题解答
回答1:>>> from eventor import Eventor>>> urllist = ['https://a.com', ....]>>> def get(url):# 网络IO耗时return url>>> e = Eventor(threadcount=3, taskunitcount=3, func=get, interval=1)>>> result = e.run_with_tasklist(urllist)>>> print(result)
自己根据需求选择 多核多进程,还是多线程,协程加快处理。
详情移步:https://github.com/kute/eventor
后续再 加进 async await,celery worker等
回答2:几个方法,并且可以结合使用
coroutine
multiprocess
multithread
celery worker
回答3:最简单的改造就是用multiprocessing.dummy 执行多线程任务,可以查一下,设置好线程数量,然后对程序不需要太大改造,大体就能用。
相关文章:
1. PHP类中的$this2. python - Django Admin创建不关联任何model的自定义页面3. javascript - h5分享链接到qq或者微信时有一个缩略图还有一些说明文字,这个要怎么去修改里面的图片和内容?4. javascript 如何下载一个excel文件 ?5. 谁有mysql5.7安装的详细教程6. mysql - 看这条sql有可能被注入吗7. python - Django操作数据库遇到问题,无法查询更新后的数据8. 请问是对象还是数组9. android - 第三方App调用高德地图,总是直接进入到导航页面,有没有办法进入首页?10. python2.7 - Python安装模组不成功
排行榜
