Python 爬蟲入門實例都有哪些,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
堅守“ 做人真誠 · 做事靠譜 · 口碑至上 · 高效敬業(yè) ”的價值觀,專業(yè)網(wǎng)站建設(shè)服務(wù)10余年為成都成都展覽展示小微創(chuàng)業(yè)公司專業(yè)提供成都企業(yè)網(wǎng)站建設(shè)營銷網(wǎng)站建設(shè)商城網(wǎng)站建設(shè)手機網(wǎng)站建設(shè)小程序網(wǎng)站建設(shè)網(wǎng)站改版,從內(nèi)容策劃、視覺設(shè)計、底層架構(gòu)、網(wǎng)頁布局、功能開發(fā)迭代于一體的高端網(wǎng)站建設(shè)服務(wù)。
帶伙伴們學(xué)習(xí)python爬蟲,準(zhǔn)備了幾個簡單的入門實例,分享給大家。
涉及主要知識點:
web是如何交互的
requests庫的get、post函數(shù)的應(yīng)用
response對象的相關(guān)函數(shù),屬性
python文件的打開,保存
代碼中給出了注釋,并且可以直接運行哦
如何安裝requests庫(安裝好python的朋友可以直接參考,沒有的,建議先裝一哈python環(huán)境)
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple requests
Linux用戶類似(ubantu為例): 權(quán)限不夠的話在命令前加入sudo即可
sudo pip install -i https://pypi.tuna.tsinghua.edu.cn/simple requests
# 第一個爬蟲示例,爬取百度頁面
import requests #導(dǎo)入爬蟲的庫,不然調(diào)用不了爬蟲的函數(shù)
response = requests.get("http://www.baidu.com") #生成一個response對象
response.encoding = response.apparent_encoding #設(shè)置編碼格式
print("狀態(tài)碼:"+ str( response.status_code ) ) #打印狀態(tài)碼
print(response.text)#輸出爬取的信息
# 第二個get方法實例
import requests #先導(dǎo)入爬蟲的庫,不然調(diào)用不了爬蟲的函數(shù)
response = requests.get("http://httpbin.org/get") #get方法
print( response.status_code ) #狀態(tài)碼
print( response.text )
# 第三個 post方法實例
import requests #先導(dǎo)入爬蟲的庫,不然調(diào)用不了爬蟲的函數(shù)
response = requests.post("http://httpbin.org/post") #post方法訪問
print( response.status_code ) #狀態(tài)碼
print( response.text )
# 第四個 put方法實例
import requests #先導(dǎo)入爬蟲的庫,不然調(diào)用不了爬蟲的函數(shù)
response = requests.put("http://httpbin.org/put") # put方法訪問
print( response.status_code ) #狀態(tài)碼
print( response.text )
如果需要傳多個參數(shù)只需要用&符號連接即可如下:
# 第五個 get傳參方法實例
import requests #先導(dǎo)入爬蟲的庫,不然調(diào)用不了爬蟲的函數(shù)
response = requests.get("http://httpbin.org/get?name=hezhi&age=20") # get傳參
print( response.status_code ) #狀態(tài)碼
print( response.text )
params用字典可以傳多個
# 第六個 get傳參方法實例
import requests #先導(dǎo)入爬蟲的庫,不然調(diào)用不了爬蟲的函數(shù)
data = {
"name":"hezhi",
"age":20
}
response = requests.get( "http://httpbin.org/get" , params=data ) # get傳參
print( response.status_code ) #狀態(tài)碼
print( response.text )
# 第七個 post傳參方法實例
import requests #先導(dǎo)入爬蟲的庫,不然調(diào)用不了爬蟲的函數(shù)
data = {
"name":"hezhi",
"age":20
}
response = requests.post( "http://httpbin.org/post" , params=data ) # post傳參
print( response.status_code ) #狀態(tài)碼
print( response.text )
# 第好幾個方法實例
import requests #先導(dǎo)入爬蟲的庫,不然調(diào)用不了爬蟲的函數(shù)
response = requests.get( "http://www.zhihu.com") #第一次訪問知乎,不設(shè)置頭部信息
print( "第一次,不設(shè)頭部信息,狀態(tài)碼:"+response.status_code )# 沒寫headers,不能正常爬取,狀態(tài)碼不是 200
#下面是可以正常爬取的區(qū)別,更改了User-Agent字段
headers = {
"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.122 Safari/537.36"
}#設(shè)置頭部信息,偽裝瀏覽器
response = requests.get( "http://www.zhihu.com" , headers=headers ) #get方法訪問,傳入headers參數(shù),
print( response.status_code ) # 200!訪問成功的狀態(tài)碼
print( response.text )
注意文件保存時的encoding設(shè)置
# 爬取一個html并保存
import requests
url = "http://www.baidu.com"
response = requests.get( url )
response.encoding = "utf-8" #設(shè)置接收編碼格式
print("\nr的類型" + str( type(response) ) )
print("\n狀態(tài)碼是:" + str( response.status_code ) )
print("\n頭部信息:" + str( response.headers ) )
print( "\n響應(yīng)內(nèi)容:" )
print( response.text )
#保存文件
file = open("D:\\爬蟲\\baidu.html","w",encoding="utf") #打開一個文件,w是文件不存在則新建一個文件,這里不用wb是因為不用保存成二進制
file.write( response.text )
file.close()
#保存百度圖片到本地
import requests #先導(dǎo)入爬蟲的庫,不然調(diào)用不了爬蟲的函數(shù)
response = requests.get("/upload/otherpic70/baidu_jgylogo3.gif") #get方法的到圖片響應(yīng)
file = open("D:\\爬蟲\\baidu_logo.gif","wb") #打開一個文件,wb表示以二進制格式打開一個文件只用于寫入
file.write(response.content) #寫入文件
file.close()#關(guān)閉操作,運行完畢后去你的目錄看一眼有沒有保存成功
看完上述內(nèi)容,你們掌握Python 爬蟲入門實例都有哪些的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!