溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

分享10個python爬蟲經(jīng)典例子

發(fā)布時間:2020-10-29 09:52:17 來源:億速云 閱讀:926 作者:小新 欄目:編程語言

小編給大家分享一下分享10個python爬蟲經(jīng)典例子,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

python爬蟲例子:首先導入爬蟲的庫,生成一個response對象;然后設置編碼格式,并打印狀態(tài)碼;最后輸出爬取的信息,代碼為【print(response.text)】。

python爬蟲例子:

1.爬取強大的BD頁面,打印頁面信息

# 第一個爬蟲示例,爬取百度頁面
import requests #導入爬蟲的庫,不然調用不了爬蟲的函數(shù)
response = requests.get("http://www.baidu.com")  #生成一個response對象
response.encoding = response.apparent_encoding #設置編碼格式
print("狀態(tài)碼:"+ str( response.status_code ) ) #打印狀態(tài)碼
print(response.text)#輸出爬取的信息
點擊并拖拽以移動

2.常用方法之get方法實例,下面還有傳參實例

# 第二個get方法實例
import requests #先導入爬蟲的庫,不然調用不了爬蟲的函數(shù)
response = requests.get("http://httpbin.org/get")  #get方法
print( response.status_code ) #狀態(tài)碼
print( response.text )
點擊并拖拽以移動

3. 常用方法之post方法實例,下面還有傳參實例

# 第三個 post方法實例
import requests #先導入爬蟲的庫,不然調用不了爬蟲的函數(shù)
response = requests.post("http://httpbin.org/post")  #post方法訪問
print( response.status_code ) #狀態(tài)碼
print( response.text )
點擊并拖拽以移動

4. put方法實例

# 第四個 put方法實例
import requests #先導入爬蟲的庫,不然調用不了爬蟲的函數(shù)
response = requests.put("http://httpbin.org/put")  # put方法訪問
print( response.status_code ) #狀態(tài)碼
print( response.text )
點擊并拖拽以移動

5.常用方法之get方法傳參實例(1)

如果需要傳多個參數(shù)只需要用&符號連接即可如下

# 第五個 get傳參方法實例
import requests #先導入爬蟲的庫,不然調用不了爬蟲的函數(shù)
response = requests.get("http://httpbin.org/get?name=hezhi&age=20")  # get傳參
print( response.status_code ) #狀態(tài)碼
print( response.text )
點擊并拖拽以移動

6.常用方法之get方法傳參實例(2)

params用字典可以傳多個

# 第六個 get傳參方法實例
import requests #先導入爬蟲的庫,不然調用不了爬蟲的函數(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 )
點擊并拖拽以移動

7.常用方法之post方法傳參實例(2) 和上一個有沒有很像

# 第七個 post傳參方法實例
import requests #先導入爬蟲的庫,不然調用不了爬蟲的函數(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 )
點擊并拖拽以移動

8.關于繞過反爬機制,以zh爸爸為例

# 第好幾個方法實例
import requests #先導入爬蟲的庫,不然調用不了爬蟲的函數(shù)
response = requests.get( "http://www.zhihu.com")  #第一次訪問知乎,不設置頭部信息
print( "第一次,不設頭部信息,狀態(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"
}#設置頭部信息,偽裝瀏覽器
response = requests.get( "http://www.zhihu.com" , headers=headers )  #get方法訪問,傳入headers參數(shù),
print( response.status_code ) # 200!訪問成功的狀態(tài)碼
print( response.text )
點擊并拖拽以移動

9.爬取信息并保存到本地,

因為目錄關系,在D盤建立了一個叫做爬蟲的文件夾,然后保存信息

注意文件保存時的encoding設置

# 爬取一個html并保存
import requests
url = "http://www.baidu.com"
response = requests.get( url )
response.encoding = "utf-8" #設置接收編碼格式
print("\nr的類型" + str( type(response) ) )
print("\n狀態(tài)碼是:" + str( response.status_code ) )
print("\n頭部信息:" + str( response.headers ) )
print( "\n響應內容:" )
print( response.text )
#保存文件
file = open("D:\\爬蟲\\baidu.html","w",encoding="utf")  #打開一個文件,w是文件不存在則新建一個文件,這里不用wb是因為不用保存成二進制
file.write( response.text )
file.close()
點擊并拖拽以移動

10.爬取圖片,保存到本地

#保存百度圖片到本地
import requests #先導入爬蟲的庫,不然調用不了爬蟲的函數(shù)
response = requests.get("https://www.baidu.com/img/baidu_jgylogo3.gif")  #get方法的到圖片響應
file = open("D:\\爬蟲\\baidu_logo.gif","wb") #打開一個文件,wb表示以二進制格式打開一個文件只用于寫入
file.write(response.content) #寫入文件
file.close()#關閉操作,運行完畢后去你的目錄看一眼有沒有保存成功

看完了這篇文章,相信你對分享10個python爬蟲經(jīng)典例子有了一定的了解,想了解更多相關知識,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI