溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Python3中urllib.error異常怎么辦

發(fā)布時(shí)間:2021-11-25 13:58:25 來(lái)源:億速云 閱讀:377 作者:小新 欄目:大數(shù)據(jù)

小編給大家分享一下Python3中urllib.error異常怎么辦,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

運(yùn)行平臺(tái):Windows
Python版本:Python3.x
IDE:Sublime text3

轉(zhuǎn)載請(qǐng)注明作者和出處:http://blog.csdn.net/c406495762/article/details/59488464

一.urllib.error

    urllib.error可以接收有urllib.request產(chǎn)生的異常。urllib.error有兩個(gè)方法,URLError和HTTPError。如下圖所示:

Python3中urllib.error異常怎么辦

Python3中urllib.error異常怎么辦

    URLError是OSError的一個(gè)子類(lèi),HTTPError是URLError的一個(gè)子類(lèi),服務(wù)器上HTTP的響應(yīng)會(huì)返回一個(gè)狀態(tài)碼,根據(jù)這個(gè)HTTP狀態(tài)碼,我們可以知道我們的訪問(wèn)是否成功。例如第二個(gè)筆記中提到的200狀態(tài)碼,表示請(qǐng)求成功,再比如常見(jiàn)的404錯(cuò)誤等。

1.URLError

    讓我們先看下URLError的異常,創(chuàng)建文件urllib_test06.py,編寫(xiě)如下代碼:

# -*- coding: UTF-8 -*-from urllib import requestfrom urllib import errorif __name__ == "__main__":#一個(gè)不存在的連接url = "http://www.iloveyou.com/"req = request.Request(url)try:
        response = request.urlopen(req)
        html = response.read().decode('utf-8')
        print(html)except error.URLError as e:
        print(e.reason)

    我們可以看到如下運(yùn)行結(jié)果:

Python3中urllib.error異常怎么辦

2.HTTPError

    再看下HTTPError異常,創(chuàng)建文件urllib_test07.py,編寫(xiě)如下代碼:

# -*- coding: UTF-8 -*-from urllib import requestfrom urllib import errorif __name__ == "__main__":#一個(gè)不存在的連接url = "http://www.douyu.com/Jack_Cui.html"req = request.Request(url)try:
        responese = request.urlopen(req)# html = responese.read()except error.HTTPError as e:
        print(e.code)

    運(yùn)行之后,我們可以看到404,這說(shuō)明請(qǐng)求的資源沒(méi)有在服務(wù)器上找到,www.douyu.com這個(gè)服務(wù)器是存在的,但是我們要查找的Jack_Cui.html資源是沒(méi)有的,所以拋出404異常。

Python3中urllib.error異常怎么辦

二.URLError和HTTPError混合使用

    最后值得注意的一點(diǎn)是,如果想用HTTPError和URLError一起捕獲異常,那么需要將HTTPError放在URLError的前面,因?yàn)镠TTPError是URLError的一個(gè)子類(lèi)。如果URLError放在前面,出現(xiàn)HTTP異常會(huì)先響應(yīng)URLError,這樣HTTPError就捕獲不到錯(cuò)誤信息了。

Python3中urllib.error異常怎么辦

    如果不用上面的方法,也可以使用hasattr函數(shù)判斷URLError含有的屬性,如果含有reason屬性表明是URLError,如果含有code屬性表明是HTTPError。創(chuàng)建文件urllib_test08.py,編寫(xiě)代碼如下:

# -*- coding: UTF-8 -*-from urllib import requestfrom urllib import errorif __name__ == "__main__":#一個(gè)不存在的連接url = "http://www.douyu.com/Jack_Cui.html"req = request.Request(url)try:
        responese = request.urlopen(req)except error.URLError as e:if hasattr(e, 'code')
            print("HTTPError")
            print(e.code)elif hasattr(e, 'reason')
            print("URLError")
            print(e.reason)

    運(yùn)行結(jié)果如下:

Python3中urllib.error異常怎么辦

以上是“Python3中urllib.error異常怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

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

AI