欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python爬蟲中的并發(fā)編程詳解

 更新時間:2023年05月04日 09:53:50   作者:互聯(lián)小助手  
Python爬蟲中的并發(fā)編程是一種優(yōu)化爬取速度、解決阻塞問題、優(yōu)化資源利用的方式。常用的并發(fā)編程模塊包括多線程、多進程、協(xié)程等,通過并發(fā)處理多個任務(wù),可以提高爬取效率,節(jié)省爬蟲資源利用成本。同時,還需注意線程安全、共享資源問題等并發(fā)編程中的常見陷阱

并發(fā)編程在爬蟲中的應(yīng)用

本文將為大家介紹 Python 中的多線程、多進程和異步編程,并且以爬取“360圖片”網(wǎng)站的圖片并保存到本地為例,為大家分別展示使用單線程、多線程和異步 I/O 編程的爬蟲程序有什么區(qū)別,同時也對它們的執(zhí)行效率進行簡單的對比。

什么是并發(fā)編程

并發(fā)編程是指在一個時間段內(nèi),能夠執(zhí)行多個操作的程序設(shè)計,通常表現(xiàn)為程序中有多個任務(wù)同時啟動,可以運行并且相互之間不會產(chǎn)生影響。并發(fā)編程的好處是可以提高程序的性能和響應(yīng)能力。

并發(fā)編程在爬蟲中的應(yīng)用

爬蟲程序是典型的 I/O 密集型任務(wù),對于 I/O 密集型任務(wù)來說,多線程和異步 I/O 都是很好的選擇,因為當(dāng)程序的某個部分因 I/O 操作阻塞時,程序的其他部分仍然可以運轉(zhuǎn),這樣我們不用在等待和阻塞中浪費大量的時間。

單線程版本

我們首先來看單線程版本的爬蟲程序。這個爬蟲程序使用了requests庫獲取 JSON 數(shù)據(jù),并通過open函數(shù)將圖片保存到本地。

"""
example04.py - 單線程版本爬蟲
"""
import os
import requests
def download_picture(url):
    filename = url[url.rfind('/') + 1:]
    resp = requests.get(url)
    if resp.status_code == 200:
        with open(f'images/beauty/{filename}', 'wb') as file:
            file.write(resp.content)
def main():
    if not os.path.exists('images/beauty'):
        os.makedirs('images/beauty')
    for page in range(3):
        resp = requests.get(f'<https://image.so.com/zjl?ch=beauty&sn=>{page * 30}')
        if resp.status_code == 200:
            pic_dict_list = resp.json()['list']
            for pic_dict in pic_dict_list:
                download_picture(pic_dict['qhimg_url'])
if __name__ == '__main__':
    main()

在 macOS 或 Linux 系統(tǒng)上,我們可以使用time命令來了解上面代碼的執(zhí)行時間以及 CPU 的利用率,如下所示。

time python3 example04.py

下面是單線程爬蟲代碼在我的電腦上執(zhí)行的結(jié)果。

python3 example04.py  2.36s user 0.39s system 12% cpu 21.578 total

這里我們只需要關(guān)注代碼的總耗時為21.578秒,CPU 利用率為12%。

多線程版本

我們使用之前講到過的線程池技術(shù),將上面的代碼修改為多線程版本。

"""
example05.py - 多線程版本爬蟲
"""
import os
from concurrent.futures import ThreadPoolExecutor
import requests
def download_picture(url):
    filename = url[url.rfind('/') + 1:]
    resp = requests.get(url)
    if resp.status_code == 200:
        with open(f'images/beauty/{filename}', 'wb') as file:
            file.write(resp.content)
def main():
    if not os.path.exists('images/beauty'):
        os.makedirs('images/beauty')
    with ThreadPoolExecutor(max_workers=16) as pool:
        for page in range(3):
            resp = requests.get(f'<https://image.so.com/zjl?ch=beauty&sn=>{page * 30}')
            if resp.status_code == 200:
                pic_dict_list = resp.json()['list']
                for pic_dict in pic_dict_list:
                    pool.submit(download_picture, pic_dict['qhimg_url'])
if __name__ == '__main__':
    main()

執(zhí)行如下所示的命令。

time python3 example05.py

代碼的執(zhí)行結(jié)果如下所示:

python3 example05.py  2.65s user 0.40s system 95% cpu 3.193 total

異步I/O版本

我們使用aiohttp將上面的代碼修改為異步 I/O 的版本。為了以異步 I/O 的方式實現(xiàn)網(wǎng)絡(luò)資源的獲取和寫文件操作,我們首先得安裝三方庫aiohttpaiofile。

pip install aiohttp aiofile

下面是異步 I/O 版本的爬蟲代碼。

"""
example06.py - 異步I/O版本爬蟲
"""
import asyncio
import json
import os
import aiofile
import aiohttp
async def download_picture(session, url):
    filename = url[url.rfind('/') + 1:]
    async with session.get(url, ssl=False) as resp:
        if resp.status == 200:
            data = await resp.read()
            async with aiofile.async_open(f'images/beauty/{filename}', 'wb') as file:
                await file.write(data)
async def main():
    if not os.path.exists('images/beauty'):
        os.makedirs('images/beauty')
    async with aiohttp.ClientSession() as session:
        tasks = []
        for page in range(3):
            resp = await session.get(f'<https://image.so.com/zjl?ch=beauty&sn=>{page * 30}')
            if resp.status == 200:
                pic_dict_list = (await resp.json())['list']
                for pic_dict in pic_dict_list:
                    tasks.append(asyncio.ensure_future(download_picture(session, pic_dict['qhimg_url'])))
        await asyncio.gather(*tasks)
if __name__ == '__main__':
    loop = asyncio.get_event_loop()
    loop.run_until_complete(main())

執(zhí)行如下所示的命令。

time python3 example06.py

代碼的執(zhí)行結(jié)果如下所示:

python3 example06.py  0.92s user 0.27s system 290% cpu 0.420 total

相對于單線程版本的爬蟲程序,多線程版本和異步 I/O 版本的爬蟲程序在執(zhí)行上的時間上有了顯著的提升,而且異步 I/O 版本的爬蟲程序表現(xiàn)最佳。

總結(jié):通過對單線程版本、多線程版本和異步 I/O 版本的爬蟲程序的對比,我們可以看出在爬蟲程序中使用異步 I/O 可以更好地發(fā)揮程序的性能和響應(yīng)能力。因此,我們在實際的開發(fā)中應(yīng)該更加注重并發(fā)編程的應(yīng)用。

到此這篇關(guān)于Python爬蟲中的并發(fā)編程詳解的文章就介紹到這了,更多相關(guān)Python并發(fā)編程內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python解釋器及PyCharm工具安裝過程

    Python解釋器及PyCharm工具安裝過程

    這篇文章主要介紹了Python解釋器和python 開發(fā)工具PyCharm安裝過程,本文通過圖文并茂的形式給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • 詳解python中的數(shù)據(jù)類型和控制流

    詳解python中的數(shù)據(jù)類型和控制流

    這篇文章主要介紹了詳解python中的數(shù)據(jù)類型和控制流,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • Python溫度轉(zhuǎn)換實例分析

    Python溫度轉(zhuǎn)換實例分析

    這篇文章主要介紹了Python溫度轉(zhuǎn)換實例分析,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • ndarray數(shù)組的轉(zhuǎn)置(transpose)和軸對換方式

    ndarray數(shù)組的轉(zhuǎn)置(transpose)和軸對換方式

    這篇文章主要介紹了ndarray數(shù)組的轉(zhuǎn)置(transpose)和軸對換方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 用Python實現(xiàn)KNN分類算法

    用Python實現(xiàn)KNN分類算法

    這篇文章主要為大家詳細介紹了用Python實現(xiàn)KNN分類算法的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • Python中格式化字符串輸出的4種方式小結(jié)

    Python中格式化字符串輸出的4種方式小結(jié)

    本文主要介紹了Python中格式化字符串輸出的4種方式小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • PowerBI和Python關(guān)于數(shù)據(jù)分析的對比

    PowerBI和Python關(guān)于數(shù)據(jù)分析的對比

    這篇文章主要介紹了PowerBI和Python關(guān)于數(shù)據(jù)分析的對比,很多經(jīng)常會用到數(shù)據(jù)分析的伙伴會問有沒有一款便捷好用的工具!肯定有啊,Python的出現(xiàn)和普及,很容易就能改變這些窘境,需要的朋友可以參考下
    2019-07-07
  • 對python讀取zip壓縮文件里面的csv數(shù)據(jù)實例詳解

    對python讀取zip壓縮文件里面的csv數(shù)據(jù)實例詳解

    今天小編就為大家分享一篇對python讀取zip壓縮文件里面的csv數(shù)據(jù)實例詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • 教你利用python的matplotlib(pyplot)繪制折線圖和柱狀圖

    教你利用python的matplotlib(pyplot)繪制折線圖和柱狀圖

    Python繪圖需要下載安裝matplotlib模塊,它是一個數(shù)學(xué)繪圖庫,我們將使用它來制作簡單的圖表,如折線圖和散點圖,下面這篇文章主要給大家介紹了關(guān)于利用python的matplotlib(pyplot)繪制折線圖和柱狀圖的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • Python正則表達式學(xué)習(xí)小例子

    Python正則表達式學(xué)習(xí)小例子

    這篇文章主要介紹了Python正則表達式學(xué)習(xí)小例子,學(xué)習(xí)python的朋友可以參考一下
    2020-03-03

最新評論