Python爬蟲之自動爬取某車之家各車銷售數(shù)據(jù)
一、目標(biāo)網(wǎng)頁分析
目標(biāo)網(wǎng)站是某車之家關(guān)于品牌汽車車型的口碑模塊相關(guān)數(shù)據(jù),比如我們演示的案例奧迪Q5L
的口碑頁面如下:
https://k.autohome.com.cn/4851/#pvareaid=3311678
為了演示方式,大家可以直接打開上面這個網(wǎng)址,然后拖到全部口碑位置,找到我們本次采集需要的字段如下圖所示:
采集字段
我們進(jìn)行翻頁發(fā)現(xiàn),瀏覽器網(wǎng)址發(fā)生了變化,大家可以對下如下幾頁的網(wǎng)址找出規(guī)律:
https://k.autohome.com.cn/4851/index_2.html#dataList https://k.autohome.com.cn/4851/index_3.html#dataList https://k.autohome.com.cn/4851/index_4.html#dataList
對于上面寫網(wǎng)址,我們發(fā)現(xiàn)可變部分是車型(如4851
)以及頁碼(如2
,3
,4
),于是我們可以構(gòu)建url
參數(shù)如下:
# typeid是車型,page是頁碼 url = f'https://k.autohome.com.cn/{typeid}/index_{page}.html#dataList'
二、數(shù)據(jù)請求
通過簡單的測試,發(fā)現(xiàn)似乎不存在反爬,那就簡單了。
我們先引入需要用到的庫:
import requests import pandas as pd import html from lxml import etree import re
然后創(chuàng)建一個數(shù)據(jù)請求的函數(shù)備用:
# 獲取網(wǎng)頁數(shù)據(jù)(傳遞參數(shù) 車型typeid和頁碼數(shù)) def get_html(typeid,page): # 組合出請求地址 url = f'https://k.autohome.com.cn/{typeid}/index_{page}.html#dataList' # 請求數(shù)據(jù)(因為沒有反爬,這里沒有設(shè)置請求頭和其他參數(shù)) r = requests.get(url) # 請求的網(wǎng)頁數(shù)據(jù)中有網(wǎng)頁特殊字符,通過以下方法進(jìn)行解析 r = html.unescape(r.text) # 返回網(wǎng)頁數(shù)據(jù) return r
請求來的數(shù)據(jù)就是網(wǎng)頁html
文本,我們接下來采用re
解析出一共多少頁碼,再用xpath
進(jìn)行采集字段的解析。
三、數(shù)據(jù)解析
由于需要進(jìn)行翻頁,這里我們可以先通過re正則表達(dá)式獲取總頁碼。通過查看網(wǎng)頁數(shù)據(jù),我們發(fā)現(xiàn)總頁碼可以通過如下方式獲取:
try: pages = int(re.findall(r'共(\d+)頁',r)[0]) # 如果請求不到頁數(shù),則表示該車型下沒有口碑?dāng)?shù)據(jù) except : print(f'{name} 沒有數(shù)據(jù)!') continue
總頁碼采集
關(guān)于待采集字段信息,我們發(fā)現(xiàn)都在節(jié)點(diǎn)div[@class="mouthcon-cont-left"]
里,可以先定位這個節(jié)點(diǎn)數(shù)據(jù),然后再進(jìn)行逐一解析。
待采集字段信息所在節(jié)點(diǎn)
此外,我們發(fā)現(xiàn)每一頁最多15個車型口碑?dāng)?shù)據(jù),因此我們每頁可以定位15個待采集信息數(shù)據(jù)集,遍歷采集代碼:
divs = r_html.xpath('.//div[@class="mouthcon-cont-left"]') # 遍歷每個全部的車輛銷售信息 for div in divs: # 找到車輛銷售信息所在的地方 mt = div.xpath('./div[@class="choose-con mt-10"]')[0] # 找到所需字段 infos = mt.xpath('./dl[@class="choose-dl"]') # 設(shè)置空的字典,用于存儲單個車輛信息 item = {} # 遍歷車輛信息字段 for info in infos: key = info.xpath('.//dt/text()')[0] # 當(dāng)字段為購買車型時,進(jìn)行拆分為車型和配置 if key == '購買車型': item[key] = info.xpath('.//dd/a/text()')[0] item['購買配置'] = info.xpath('.//span[@class="font-arial"]/text()')[0] # 當(dāng)字段為購車經(jīng)銷商時,需要獲取經(jīng)銷商的id參數(shù),再調(diào)用api獲取其真實經(jīng)銷商信息(這里有坑) elif key == '購車經(jīng)銷商': # 經(jīng)銷商id參數(shù) 經(jīng)銷商id = info.xpath('.//dd/a/@data-val')[0] +','+ info.xpath('.//dd/a/@data-evalid')[0] # 組合經(jīng)銷商信息請求地址 jxs_url = base_jxs_url+經(jīng)銷商id+'|' # 請求數(shù)據(jù)(為json格式) data = requests.get(jxs_url) j = data.json() # 獲取經(jīng)銷商名稱 item[key] = j['result']['List'][0]['CompanySimple'] else: # 其他字段時,替換轉(zhuǎn)義字符和空格等為空 item[key] = info.xpath('.//dd/text()')[0].replace("\r\n","").replace(' ','').replace('\xa0','')
四、數(shù)據(jù)存儲
由于沒啥反爬,這里直接將采集到的數(shù)據(jù)轉(zhuǎn)化為pandas.DataFrame
類型,然后存儲為xlsx
文件即可。
df = pd.DataFrame(items) df = df[['購買車型', '購買配置', '購買地點(diǎn)', '購車經(jīng)銷商', '購買時間', '裸車購買價']] # 數(shù)據(jù)存儲在本地 df.to_excel(r'車輛銷售信息.xlsx',index=None,sheet_name='data')
五、采集結(jié)果預(yù)覽
整個爬蟲過程比較簡單,采集下來的數(shù)據(jù)也比較規(guī)范,以本文案例奧迪Q5L示例如下:
到此這篇關(guān)于Python爬蟲之自動采集某車之家各車銷售數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Python采集汽車銷售數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python循環(huán)結(jié)構(gòu)的應(yīng)用場景詳解
這篇文章主要介紹了Python循環(huán)結(jié)構(gòu)的應(yīng)用場景詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-07-07Python實現(xiàn)統(tǒng)計文本中字符的方法小結(jié)
在計算機(jī)編程中,經(jīng)常需要對文本數(shù)據(jù)進(jìn)行處理和分析,字符統(tǒng)計是其中一個常見任務(wù),本文將詳細(xì)介紹如何使用Python進(jìn)行字符統(tǒng)計,希望對大家有所幫助2024-01-01pymysql.err.DataError:1366的報錯解決
通過python把數(shù)據(jù)同步至mysql數(shù)據(jù)庫的過程中,遇到錯誤,本文主要介紹了pymysql.err.DataError:1366的報錯解決,具有一定的參考價值,感興趣的可以了解一下2024-05-05利用Python+Java調(diào)用Shell腳本時的死鎖陷阱詳解
這篇文章主要給大家介紹了關(guān)于利用Python+Java調(diào)用Shell腳本時的死鎖陷阱的相關(guān)資料,文章通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01python利用appium實現(xiàn)手機(jī)APP自動化的示例
這篇文章主要介紹了python利用appium實現(xiàn)手機(jī)APP自動化的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01Python爬蟲urllib和requests的區(qū)別詳解
這篇文章主要介紹了Python爬蟲urllib和requests的區(qū)別詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09運(yùn)動檢測ViBe算法python實現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了運(yùn)動檢測ViBe算法python實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01