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

Python爬蟲之urllib基礎(chǔ)用法教程

 更新時(shí)間:2019年10月12日 09:43:03   作者:ZhiHuaWei  
這篇文章主要為大家詳細(xì)介紹了Python爬蟲1.1 urllib基礎(chǔ)用法教程,用于對(duì)Python爬蟲技術(shù)進(jìn)行系列文檔講解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

綜述

本系列文檔用于對(duì)Python爬蟲技術(shù)進(jìn)行簡單的教程講解,鞏固自己技術(shù)知識(shí)的同時(shí),萬一一不小心又正好對(duì)你有用那就更好了。

Python 版本是3.7.4

urllib庫介紹

它是 Python 內(nèi)置的HTTP請(qǐng)求庫,也就是說我們不需要額外安裝即可使用,它包含四個(gè)模塊(主要對(duì)前三個(gè)模塊進(jìn)行學(xué)習(xí)):

  • request : 它是最基本的 HTTP 請(qǐng)求模塊,我們可以用它來模擬發(fā)送一請(qǐng)求,就像在瀏覽器里輸入網(wǎng)址然后敲擊回車一樣,只需要給庫方法傳入 URL 還有額外的參數(shù),就可以模擬實(shí)現(xiàn)這個(gè)過程了。
  • error : 異常處理模塊,如果出現(xiàn)請(qǐng)求錯(cuò)誤,我們可以捕獲這些異常,然后進(jìn)行重試或其他操作保證程序不會(huì)意外終止。
  • parse : 用于解析URL,提供了許多URL處理方法,比如拆分、解析、合并等等的方法,以及對(duì)參數(shù)的拼接等待。
  • robotparser : 主要是用來識(shí)別網(wǎng)站的robots.txt協(xié)議文件,然后判斷網(wǎng)站的那些數(shù)據(jù)可以爬,哪些數(shù)據(jù)不可以爬的,其實(shí)用的比較少。

urllib.request 介紹

urlopen()

1.參數(shù)說明(僅寫了四個(gè)最常用的參數(shù))

url : 爬取目標(biāo)的URL;
data : 請(qǐng)求參數(shù),如果設(shè)置該參數(shù),則請(qǐng)求默認(rèn)為post請(qǐng)求;沒有默認(rèn)為get請(qǐng)求;
timeout : 用于設(shè)置超時(shí)時(shí)間,單位為秒;
context : 必須是一個(gè)ssl.SSLContext類型,用來指定SSL設(shè)置,忽略未認(rèn)證的CA證書;

2.具體用法

GET 請(qǐng)求方式

# 導(dǎo)入urllib庫
import urllib.request
 
 # 向指定的url發(fā)送請(qǐng)求,并返回服務(wù)器響應(yīng)的類文件對(duì)象
 url = "http://www.baidu.com"
 response = urllib.request.urlopen(url=url)
 print(type(response))
 
 # 類文件對(duì)象支持文件對(duì)象的操作方法,如read()方法讀取文件全部內(nèi)容,返回字符串
 html = response.read()
 # html = response.readline() # 讀取一行
 # html = response.readlines() # 讀取多行,返回列表
 # 打印響應(yīng)結(jié)果(byte類型)
 print(html)
 # 打印響應(yīng)結(jié)果(utf-8類型)
 # 二進(jìn)制和字符串之間的相互轉(zhuǎn)碼使用 encode() 和 decode() 函數(shù)
 # encode() 和 decode() 可帶參數(shù),不寫默認(rèn)utf-8,其他不再特別說明
 print(html.decode())
 # 打印狀態(tài)碼
 # print(response.get_code())
 print(response.status)
 # 獲取響應(yīng)頭
 print(response.getheaders())
 # 獲取響應(yīng)頭Server信息
 print(response.getheader('Server'))
 # 獲取響應(yīng)結(jié)果原因
 print(response.reason)

POST 請(qǐng)求方式

# 導(dǎo)入urllib庫
import urllib.parse
import urllib.request
 
 # 向指定的url發(fā)送請(qǐng)求,并返回
 post_url = 'https://fanyi.baidu.com/sug'
 # 傳入?yún)?shù)
 form_data = {
 'kw': 'honey'
 }
 # 格式化參數(shù)
 form_data = urllib.parse.urlencode(form_data).encode()
 
 response = urllib.request.urlopen(url=post_url, data=form_data)
 # 打印服務(wù)器響應(yīng)的類文件對(duì)象
 print(type(response))
 
 # 類文件對(duì)象支持文件對(duì)象的操作方法,如read()方法讀取文件全部內(nèi)容,返回字符串
 html = response.read()
 # 打印響應(yīng)結(jié)果(byte類型)
 print(html)
 # 打印響應(yīng)結(jié)果(utf-8類型)
 print(html.decode())
 # 打印狀態(tài)碼
 print(response.status)
 # print(response.getcode())
 # 獲取響應(yīng)頭
 print(response.getheaders())
 # 獲取響應(yīng)頭Server信息
 print(response.getheader('Server'))
 # 獲取響應(yīng)結(jié)果原因
 print(response.reason)

urlretrleve()

1.參數(shù)說明

url : 下載鏈接地址;
filename : 指定保存本地路徑(如果參數(shù)未指定,urllib會(huì)生成一個(gè)臨時(shí)文件保存數(shù)據(jù));
reporthook : 是一個(gè)回調(diào)函數(shù),當(dāng)連接上服務(wù)器、以及相應(yīng)的數(shù)據(jù)塊傳輸完畢時(shí)會(huì)觸發(fā)該回調(diào),我們可以利用這個(gè)回調(diào)函數(shù)來顯示當(dāng)前的下載進(jìn)度;
data : 指post導(dǎo)服務(wù)器的數(shù)據(jù),該方法返回一個(gè)包含兩個(gè)元素的(filename, headers) 元組,filename 表示保存到本地的路徑,header表示服務(wù)器的響應(yīng)頭;

2.具體用法

# 引入所需要的庫
import os
import urllib.request
 
 
 # 定義回調(diào)函數(shù)
 def call_back(a, b, c):
 """
 圖片下載回調(diào)
 :param a: 已經(jīng)下載的數(shù)據(jù)塊
 :param b: 數(shù)據(jù)塊的大小
 :param c: 遠(yuǎn)程文件的大小
 :return: 
 """
 per = 100.0 * a * b / c
 if per > 100:
 per = 100
 print('%.2f%%' % per)
 
 
 # 定義下下載的地址
 url = 'http://www.baidu.com'
 # 構(gòu)造文件保存路徑
 path = os.path.abspath('.')
 file_path = os.path.join(path, 'baidu.html')
 # 進(jìn)行下載
 urllib.request.urlretrieve(url, file_path, call_back)

urllib.parse 介紹

urlencode()

1.參數(shù)說明

query : url參數(shù),可以是字符串,也可以是字典;
encoding : 編碼方式;

2.具體用法

# 引入所需要的庫
import urllib.parse
# 參數(shù)數(shù)據(jù)
 data = {
 'name': '張三',
 'age': 26
 }
 # 進(jìn)行編碼
 ret = urllib.parse.urlencode(data)
 print(ret)

parse_s()

1.參數(shù)說明

qs : url參數(shù),編碼后的字符串;
encoding : 字符方式;

2.具體用法

# 引入所需要的庫
import urllib.parse
# 參數(shù)數(shù)據(jù)
data = {
 'name': '張三',
 'age': 26
 }
 # 進(jìn)行編碼
 ret1 = urllib.parse.urlencode(data)
 print(ret1)
 # 進(jìn)行解碼
 ret2 = urllib.parse.parse_qs(ret1)
 print(ret2)

urlparse()

1.參數(shù)說明

url : url地址字符串;

2.具體用法

# 引入所需要的庫
import urllib.parse
# 聲明url
 url = "https://www.baidu.com/s?wd=urlparse&rsv_spt=1&rsv_iqid=0x921f00fe005646ef&issp=1&f=8"
 # 進(jìn)行url解析
 ret = urllib.parse.urlparse(url)
 print(ret)
 print('scheme:', ret.scheme) # 協(xié)議
 print('netloc:', ret.netloc) # 域名服務(wù)器
 print('path:', ret.path) # 相對(duì)路徑
 print('params:', ret.params) # 路徑端參數(shù)
 print('fragment:', ret.fragment) # 片段
 print('query:', ret.query) # 查詢
 
 # urlunparse() 與 urlparse() 對(duì)應(yīng)相反函數(shù)
 # 使用urlparse的格式組合成一個(gè)url,可以直接將urlparse的返回傳遞組合
 ret1 = urllib.parse.urlunparse(ret)
 print(ret1)

urlsplit()

1.參數(shù)說明

url : url地址字符串;

2.具體用法

# 引入所需要的庫
import urllib.parse
# 聲明url
 url = "https://www.baidu.com/s?wd=urlparse&rsv_spt=1&rsv_iqid=0x921f00fe005646ef&issp=1&f=8"
 # 進(jìn)行url解析
 ret = urllib.parse.urlsplit(url)
 print(ret)
 print('scheme:', ret.scheme) # 協(xié)議
 print('netloc:', ret.netloc) # 域名服務(wù)器
 print('path:', ret.path) # 相對(duì)路徑
 print('fragment:', ret.fragment) # 片段
 print('query:', ret.query) # 查詢
 
 # urlunsplit() 與 urlsplit() 對(duì)應(yīng)相反函數(shù)
 # 使用urlsplit的格式組合成一個(gè)url,可以直接將urlsplit的返回傳遞組合
 ret1 = urllib.parse.urlunsplit(ret)
 print(ret1)
 
 # 此函數(shù)和urlparse函數(shù)的區(qū)別在于此函數(shù)沒有params

urljoin()

1.參數(shù)說明

qs : url參數(shù),編碼后的字符串;
encoding : 字符方式;

2.具體用法

# 引入所需要的庫
import urllib.parse
 
 # 聲明url
 url = "https://www.baidu.com/"
 # 參數(shù)數(shù)據(jù)
 data = {
 'name': '張三',
 'age': 26
 }
 # 格式化參數(shù)
 data = urllib.parse.urlencode(data)
 # 進(jìn)行url拼接
 ret = urllib.parse.urljoin(url, data)
 print(ret)

urllib.error 介紹

我們?cè)谂老x的時(shí)候發(fā)請(qǐng)求的時(shí)候難免出現(xiàn)錯(cuò)誤,如訪問不到服務(wù)器或者訪問被禁止等等,error分為URLError和HTTPError兩類:

1.URLError

沒有網(wǎng)
服務(wù)器鏈接失敗
找不大指定服務(wù)器

2.HTTPError

是URLError的子類

3.兩者區(qū)別和聯(lián)系

1).URLError封裝的錯(cuò)誤信息一般是由網(wǎng)絡(luò)引起的,包括url錯(cuò)誤
2).HTTPError封裝的錯(cuò)誤信息一般是服務(wù)器返回了錯(cuò)誤狀態(tài)碼
3).URLError是OSERROR的子類,HTTPError是URLError的子類
4).【注意】兩個(gè)同時(shí)捕獲的時(shí)候需要將子類放在上面,父類放在下面

用法

# 引入所需要的庫
import urllib.error
import urllib.request
 
 # 一個(gè)訪問異常的url
 url = 'https://www.mz.com/156427/100'
 # 捕獲異常
 try:
 ret = urllib.request.urlopen(url)
 print(ret)
 except urllib.error.HTTPError as e:
 print(e.getcode())
 except urllib.error.URLError as e:
 print(e)

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Pycharm中SSH、SFTP連接遠(yuǎn)程服務(wù)器編輯調(diào)試實(shí)例

    Pycharm中SSH、SFTP連接遠(yuǎn)程服務(wù)器編輯調(diào)試實(shí)例

    這篇文章主要介紹了Pycharm中SSH、SFTP連接遠(yuǎn)程服務(wù)器編輯調(diào)試實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Python處理字符串中文(漢字)編碼的實(shí)例

    Python處理字符串中文(漢字)編碼的實(shí)例

    這篇文章主要介紹了Python處理字符串中文(漢字)編碼的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Python+Kepler.gl實(shí)現(xiàn)時(shí)間輪播地圖過程解析

    Python+Kepler.gl實(shí)現(xiàn)時(shí)間輪播地圖過程解析

    這篇文章主要介紹了Python+Kepler.gl實(shí)現(xiàn)時(shí)間輪播地圖過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • 關(guān)于numpy版本兼容問題解決方案

    關(guān)于numpy版本兼容問題解決方案

    這篇文章主要給大家介紹了關(guān)于numpy版本兼容問題解決方案的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用numpy具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-10-10
  • python3操作redis實(shí)現(xiàn)List列表實(shí)例

    python3操作redis實(shí)現(xiàn)List列表實(shí)例

    本文主要介紹了python3操作redis實(shí)現(xiàn)List列表實(shí)例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 深入flask之異步非堵塞實(shí)現(xiàn)代碼示例

    深入flask之異步非堵塞實(shí)現(xiàn)代碼示例

    這篇文章主要介紹了深入flask之異步非堵塞實(shí)現(xiàn)代碼示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-07-07
  • Python Django ORM與模型詳解

    Python Django ORM與模型詳解

    這篇文章主要介紹了django的ORM與模型的實(shí)現(xiàn)原理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧v
    2021-11-11
  • 最新評(píng)論