Python requests及aiohttp速度對(duì)比代碼實(shí)例
環(huán)境:centos7 python3.6
測(cè)試網(wǎng)址:www.bai.com
測(cè)試方式:抓取百度100次
結(jié)果:
aio: 10.702147483825684s
requests: 12.404678583145142s
異步框架的速度還是有顯著提升的。
下面貢獻(xiàn)代碼:
import aiohttp
import time
import requests
import asyncio
def test_requests():
""" 測(cè)試requessts請(qǐng)求百度100次時(shí)間 """
start = time.time()
url = "https://www.baidu.com"
for i in range(100):
requests.get(url)
end = time.time()
print("requests:")
print( end - start )
async def aio_download(url):
""" aiohttp 下載 """
async with aiohttp.ClientSession() as session:
await session.get(url)
async def test_aio():
""" 測(cè)試aiohtpp請(qǐng)求百度100次時(shí)間 """
url = "https://www.baidu.com"
start = time.time()
for i in range(100):
await aio_download(url)
end = time.time()
print("aio: ")
print( end - start )
if __name__ == "__main__":
loop = asyncio.get_event_loop()
loop.run_until_complete(test_aio())
test_requests()
————————————————————————————————————————
-—————————————————————————————————————————
小貼士:
requests不要使用session進(jìn)行反復(fù)抓取一個(gè)網(wǎng)站的測(cè)試,因?yàn)閺牡?次開(kāi)始,讀取的就是緩存了,無(wú)論抓取50次還是100次或是更多,總時(shí)間都是1s以內(nèi)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
?python中字符串的常見(jiàn)操作總結(jié)(二)
這篇文章主要介紹了python中字符串的常見(jiàn)操作,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07
Python使用函數(shù)輔助工具簡(jiǎn)化開(kāi)發(fā)提高效率
這篇文章主要為大家介紹了Python使用函數(shù)輔助工具簡(jiǎn)化開(kāi)發(fā)提高效率,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01
Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)讓字典保持有序的方法
這篇文章主要介紹了Python讓字典保持有序的方法,涉及Python基于collections模塊中的OrderedDict類(lèi)實(shí)現(xiàn)控制字典順序的相關(guān)操作技巧,需要的朋友可以參考下2018-02-02
解決Python 函數(shù)聲明先后順序出現(xiàn)的問(wèn)題
這篇文章主要介紹了如何解決Python 函數(shù)聲明先后順序的問(wèn)題,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下2020-09-09

