Python爬蟲15--爬蟲遇上多執行緒,速度更上一層樓,爬取1000張圖片連一分鐘也不要!
將多執行緒和爬蟲結合,能將爬取速度更上一層樓,爬取1000張圖片連一分鐘也不要!
百度圖片對於爬蟲相當的友好,基本不需要做反反爬蟲的設定,點贊 :)
1.分析百度圖片網址:
從百度進去搜尋圖片,例如搜尋 “拳皇” ,很大可能會看到位址列出現一大坨東西,就像這樣:
https://image.baidu.com/search/index?tn=baiduimage&ipn=r&ct=201326592&cl=2&lm=-1&st=-1&fm=result&fr=&sf=1&fmq=1609662428291_R&pv=&ic=&nc=1&z=&hd=&latest=©right=&se=1&showtab=0&fb=0&width=&height=&face=0&istype=2&ie=utf-8&hs=2&sid=&word=%E6%8B%B3%E7%9A%87
看的人頭疼,將這個難看的URL地址拿到URL解析網站解析一下看看,發現最後的一串資料就是我們要找的圖片名稱:
其實,URL中有很多內容對於我們爬蟲來說,其實是可有可無的,大部分 “&” 符號後面的引數都可以去掉,“?”之後的引數也是如此,但這個URL是例外。
不認識的都可以試著刪除,要用的話大不了之後再加回來,得到了如下URL地址,怎麼樣,舒服多了吧。這就是初始URL了。
https://image.baidu.com/search/index?tn=baiduimage&word=%E6%8B%B3%E7%9A%87
2.尋找圖片資訊
開啟瀏覽器自帶的抓包工具,重新載入一下網站,耐心的尋找響應,最後終於找到了。圖片的地址居然藏在Json中,那事情似乎變得簡單了起來。
3.直接上程式碼吧,請求圖片可能比較慢,直接上5個執行緒。不用怕速度太快被反爬
import requests
import json
import threading
from queue import Queue
import os
class ImgSpider:
def __init__(self, img_name, list_number):
self.img_name = img_name
self.list_number = int(list_number//30) + 1
self.original_url = 'https://image.baidu.com/search/acjson?tn=resultjson_com&pn={}&ipn=rj&word={}'
self.start_url = 'https://image.baidu.com/search/acjson?tn=resultjson_com&pn=0&ipn=rj&word={}'.format(img_name)
self.headers = {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.88 Safari/537.36"}
self.url_list_queue = Queue()
self.response_url_queue = Queue()
self.img_list_queue = Queue()
self.img_content_queue = Queue()
# 生成目標url列表
def url_list(self):
for i in range(self.list_number):
url = self.original_url.format(i * 30, self.img_name)
self.url_list_queue.put(url)
# 對目標url列表進行爬取
def parse_url(self):
while True:
url = self.url_list_queue.get()
response = requests.get(url, headers=self.headers)
self.response_url_queue.put(response.content.decode())
self.url_list_queue.task_done()
# 提取圖片地址
def get_img_url(self):
while True:
content = self.response_url_queue.get()
content = json.loads(content)
for i in content["data"][0:-1]:
url = i['thumbURL']
# print(url)
self.img_list_queue.put(url)
self.response_url_queue.task_done()
# 從圖片列表中取出地址傳送請求
def parse_img_list(self):
while True:
url = self.img_list_queue.get()
print('正在請求:', url)
response = requests.get(url, headers=self.headers)
self.img_content_queue.put(response.content)
self.img_list_queue.task_done()
# 儲存圖片
def save_img(self):
os.mkdir(self.img_name)
count = 0
while True:
if self.img_content_queue:
path = '{}/{}'.format(self.img_name, self.img_name)
with open(path + '{}.png'.format(count), 'wb') as f:
content = self.img_content_queue.get()
f.write(content)
count += 1
self.img_content_queue.task_done()
def run(self):
# 1.獲取start_url,構造url_list
self.url_list()
# 2.傳送請求獲取url資訊
ls = []
t1 = threading.Thread(target=self.parse_url)
ls.append(t1)
# 3.提取圖片地址
t2 = threading.Thread(target=self.get_img_url)
ls.append(t2)
# 4.請求圖片資訊
for i in range(5):
t3 = threading.Thread(target=self.parse_img_list)
ls.append(t3)
# 5.儲存圖片
t4 = threading.Thread(target=self.save_img)
ls.append(t4)
for i in ls:
i.setDaemon(True)
i.start()
self.url_list_queue.join()
self.response_url_queue.join()
self.img_list_queue.join()
self.img_content_queue.join()
img_name = input("輸入要下載的圖片名稱:")
list_number = int(input("下載數量(自動補齊成30的倍數):"))
img = ImgSpider(img_name, list_number)
img.run()
相關文章
- Python爬蟲入門【9】:圖蟲網多執行緒爬取Python爬蟲執行緒
- python爬蟲---網頁爬蟲,圖片爬蟲,文章爬蟲,Python爬蟲爬取新聞網站新聞Python爬蟲網頁網站
- python多執行緒爬蟲與單執行緒爬蟲效率效率對比Python執行緒爬蟲
- Python爬蟲入門【10】:電子書多執行緒爬取Python爬蟲執行緒
- 多執行緒爬蟲實現(上)執行緒爬蟲
- Python爬蟲—爬取某網站圖片Python爬蟲網站
- Python《多執行緒併發爬蟲》Python執行緒爬蟲
- Java爬蟲批量爬取圖片Java爬蟲
- Python爬蟲入門【5】:27270圖片爬取Python爬蟲
- Python使用多程式提高網路爬蟲的爬取速度Python爬蟲
- 爬蟲 Scrapy框架 爬取圖蟲圖片並下載爬蟲框架
- node:爬蟲爬取網頁圖片爬蟲網頁
- 爬蟲---xpath解析(爬取美女圖片)爬蟲
- Python爬蟲入門教程 13-100 鬥圖啦表情包多執行緒爬取Python爬蟲執行緒
- python多執行緒非同步爬蟲-Python非同步爬蟲試驗[Celery,gevent,requests]Python執行緒非同步爬蟲
- Python爬蟲實戰詳解:爬取圖片之家Python爬蟲
- 【python--爬蟲】千圖網高清背景圖片爬蟲Python爬蟲
- 【Python學習】爬蟲爬蟲爬蟲爬蟲~Python爬蟲
- 如何合理控制爬蟲爬取速度?爬蟲
- python爬蟲入門八:多程式/多執行緒Python爬蟲執行緒
- 簡易多執行緒爬蟲框架執行緒爬蟲框架
- Python爬蟲新手教程: 知乎文章圖片爬取器Python爬蟲
- Python爬蟲遞迴呼叫爬取動漫美女圖片Python爬蟲遞迴
- 爬蟲:多程式爬蟲爬蟲
- python爬蟲之多執行緒、多程式+程式碼示例Python爬蟲執行緒
- Python爬蟲入門教程 11-100 行行網電子書多執行緒爬取Python爬蟲執行緒
- 新手爬蟲教程:Python爬取知乎文章中的圖片爬蟲Python
- 資料提取方法-多程式多執行緒爬蟲執行緒爬蟲
- 【python--爬蟲】彼岸圖網高清桌布爬蟲Python爬蟲
- python爬蟲58同城(多個資訊一次爬取)Python爬蟲
- 網路爬蟲---從千圖網爬取圖片到本地爬蟲
- Python爬蟲入門教程 50-100 Python3爬蟲爬取VIP視訊-Python爬蟲6操作Python爬蟲
- Python網路爬蟲2 - 爬取新浪微博使用者圖片Python爬蟲
- Python爬蟲入門【4】:美空網未登入圖片爬取Python爬蟲
- 爬蟲Selenium+PhantomJS爬取動態網站圖片資訊(Python)爬蟲JS網站Python
- Python 第一個爬蟲,爬取 147 小說Python爬蟲
- python 爬蟲 爬取 learnku 精華文章Python爬蟲
- python爬蟲初探--第一個python爬蟲專案Python爬蟲