文章詳情頁
python 加快程序運行問題
瀏覽:102日期: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. css - 如何使用 vue transition 實現 ios 按鈕一樣的平滑切換效果2. javascript - jQuery中live事件在移動微信端下沒有效果;代碼如下3. python 如何實現PHP替換圖片 鏈接4. <tr valign="top"> 看不懂5. 系統重裝后,恢復mysql5.5?6. java - 關于柱狀圖表展示高度的問題。7. java 隨機延遲執行8. angular.js - 在終端中用yeoman啟用angular-generator報錯,求解?9. 在mac下出現了兩個docker環境10. 更新mysql中被別人鎖定的行, 能不能快速失敗直接報錯, 而不是一直等待
排行榜
