99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀Python 異常處理_python 拋出異常_python 異常捕獲
Python 異常處理_python 拋出異常_python 異常捕獲
2017-01-01
收藏

Python 異常處理_python 拋出異常_python 異常捕獲

python提供了兩個非常重要的功能來處理python程序在運行中出現(xiàn)的異常和錯誤。你可以使用該功能來調(diào)試python程序。
異常處理: 本站Python教程會具體介紹。
斷言(Assertions):本站Python教程會具體介紹。
python標(biāo)準(zhǔn)異常
異常名稱    描述
BaseException    所有異常的基類
SystemExit    解釋器請求退出
KeyboardInterrupt    用戶中斷執(zhí)行(通常是輸入^C)
Exception    常規(guī)錯誤的基類
StopIteration    迭代器沒有更多的值
GeneratorExit    生成器(generator)發(fā)生異常來通知退出
StandardError    所有的內(nèi)建標(biāo)準(zhǔn)異常的基類
ArithmeticError    所有數(shù)值計算錯誤的基類
FloatingPointError    浮點計算錯誤
OverflowError    數(shù)值運算超出最大限制
ZeroDivisionError    除(或取模)零 (所有數(shù)據(jù)類型)
AssertionError    斷言語句失敗
AttributeError    對象沒有這個屬性
EOFError    沒有內(nèi)建輸入,到達EOF 標(biāo)記
EnvironmentError    操作系統(tǒng)錯誤的基類
IOError    輸入/輸出操作失敗
OSError    操作系統(tǒng)錯誤
WindowsError    系統(tǒng)調(diào)用失敗
ImportError    導(dǎo)入模塊/對象失敗
LookupError    無效數(shù)據(jù)查詢的基類
IndexError    序列中沒有此索引(index)
KeyError    映射中沒有這個鍵
MemoryError    內(nèi)存溢出錯誤(對于Python 解釋器不是致命的)
NameError    未聲明/初始化對象 (沒有屬性)
UnboundLocalError    訪問未初始化的本地變量
ReferenceError    弱引用(Weak reference)試圖訪問已經(jīng)垃圾回收了的對象
RuntimeError    一般的運行時錯誤
NotImplementedError    尚未實現(xiàn)的方法
SyntaxError    Python 語法錯誤
IndentationError    縮進錯誤
TabError    Tab 和空格混用
SystemError    一般的解釋器系統(tǒng)錯誤
TypeError    對類型無效的操作
ValueError    傳入無效的參數(shù)
UnicodeError    Unicode 相關(guān)的錯誤
UnicodeDecodeError    Unicode 解碼時的錯誤
UnicodeEncodeError    Unicode 編碼時錯誤
UnicodeTranslateError    Unicode 轉(zhuǎn)換時錯誤
Warning    警告的基類
DeprecationWarning    關(guān)于被棄用的特征的警告
FutureWarning    關(guān)于構(gòu)造將來語義會有改變的警告
OverflowWarning    舊的關(guān)于自動提升為長整型(long)的警告
PendingDeprecationWarning    關(guān)于特性將會被廢棄的警告
RuntimeWarning    可疑的運行時行為(runtime behavior)的警告
SyntaxWarning    可疑的語法的警告
UserWarning    用戶代碼生成的警告
什么是異常?
異常即是一個事件,該事件會在程序執(zhí)行過程中發(fā)生,影響了程序的正常執(zhí)行。
一般情況下,在Python無法正常處理程序時就會發(fā)生一個異常。
異常是Python對象,表示一個錯誤。

當(dāng)Python腳本發(fā)生異常時我們需要捕獲處理它,否則程序會終止執(zhí)行。

異常處理

捕捉異??梢允褂胻ry/except語句。

try/except語句用來檢測try語句塊中的錯誤,從而讓except語句捕獲異常信息并處理。

如果你不想在異常發(fā)生時結(jié)束你的程序,只需在try里捕獲它。

語法:

以下為簡單的try….except…else的語法:

try:
<語句>        #運行別的代碼
except <名字>:
<語句>        #如果在try部份引發(fā)了'name'異常
except <名字>,<數(shù)據(jù)>:
<語句>        #如果引發(fā)了'name'異常,獲得附加的數(shù)據(jù)
else:
<語句>        #如果沒有異常發(fā)生
try的工作原理是,當(dāng)開始一個try語句后,python就在當(dāng)前程序的上下文中作標(biāo)記,這樣當(dāng)異常出現(xiàn)時就可以回到這里,try子句先執(zhí)行,接下來會發(fā)生什么依賴于執(zhí)行時是否出現(xiàn)異常。

如果當(dāng)try后的語句執(zhí)行時發(fā)生異常,python就跳回到try并執(zhí)行第一個匹配該異常的except子句,異常處理完畢,控制流就通過整個try語句(除非在處理異常時又引發(fā)新的異常)。
如果在try后的語句里發(fā)生了異常,卻沒有匹配的except子句,異常將被遞交到上層的try,或者到程序的最上層(這樣將結(jié)束程序,并打印缺省的出錯信息)。
如果在try子句執(zhí)行時沒有發(fā)生異常,python將執(zhí)行else語句后的語句(如果有else的話),然后控制流通過整個try語句。
實例
下面是簡單的例子,它打開一個文件,在該文件中的內(nèi)容寫入內(nèi)容,且并未發(fā)生異常:

#!/usr/bin/python
# -*- coding: UTF-8 -*-

try:
    fh = open("testfile", "w")
    fh.write("這是一個測試文件,用于測試異常!!")
except IOError:
    print "Error: 沒有找到文件或讀取文件失敗"
else:
    print "內(nèi)容寫入文件成功"
    fh.close()
以上程序輸出結(jié)果:

$ python test.py
內(nèi)容寫入文件成功
$ cat testfile       # 查看寫入的內(nèi)容
這是一個測試文件,用于測試異常!!
實例
下面是簡單的例子,它打開一個文件,在該文件中的內(nèi)容寫入內(nèi)容,但文件沒有寫入權(quán)限,發(fā)生了異常:

#!/usr/bin/python
# -*- coding: UTF-8 -*-

try:
    fh = open("testfile", "w")
    fh.write("這是一個測試文件,用于測試異常!!")
except IOError:
    print "Error: 沒有找到文件或讀取文件失敗"
else:
    print "內(nèi)容寫入文件成功"
    fh.close()
在執(zhí)行代碼前為了測試方便,我們可以先去掉 testfile 文件的寫權(quán)限,命令如下:

chmod -w testfile
再執(zhí)行以上代碼:

$ python test.py
Error: 沒有找到文件或讀取文件失敗
使用except而不帶任何異常類型

你可以不帶任何異常類型使用except,如下實例:

try:
    正常的操作
   ......................
except:
    發(fā)生異常,執(zhí)行這塊代碼
   ......................
else:
    如果沒有異常執(zhí)行這塊代碼
以上方式try-except語句捕獲所有發(fā)生的異常。但這不是一個很好的方式,我們不能通過該程序識別出具體的異常信息。因為它捕獲所有的異常。

使用except而帶多種異常類型

你也可以使用相同的except語句來處理多個異常信息,如下所示:

try:
    正常的操作
   ......................
except(Exception1[, Exception2[,...ExceptionN]]]):
   發(fā)生以上多個異常中的一個,執(zhí)行這塊代碼
   ......................
else:
    如果沒有異常執(zhí)行這塊代碼
try-finally 語句

try-finally 語句無論是否發(fā)生異常都將執(zhí)行最后的代碼。

try:
<語句>
finally:
<語句>    #退出try時總會執(zhí)行
raise
實例
#!/usr/bin/python
# -*- coding: UTF-8 -*-

try:
    fh = open("testfile", "w")
    fh.write("這是一個測試文件,用于測試異常!!")
finally:
    print "Error: 沒有找到文件或讀取文件失敗"
如果打開的文件沒有可寫權(quán)限,輸出如下所示:

$ python test.py
Error: 沒有找到文件或讀取文件失敗
同樣的例子也可以寫成如下方式:

#!/usr/bin/python
# -*- coding: UTF-8 -*-

try:
    fh = open("testfile", "w")
    try:
        fh.write("這是一個測試文件,用于測試異常!!")
    finally:
        print "關(guān)閉文件"
        fh.close()
except IOError:
    print "Error: 沒有找到文件或讀取文件失敗"
當(dāng)在try塊中拋出一個異常,立即執(zhí)行finally塊代碼。

finally塊中的所有語句執(zhí)行后,異常被再次觸發(fā),并執(zhí)行except塊代碼。

參數(shù)的內(nèi)容不同于異常。

異常的參數(shù)

一個異??梢詭蠀?shù),可作為輸出的異常信息參數(shù)。

你可以通過except語句來捕獲異常的參數(shù),如下所示:

try:
    正常的操作
   ......................
except ExceptionType, Argument:
    你可以在這輸出 Argument 的值...
變量接收的異常值通常包含在異常的語句中。在元組的表單中變量可以接收一個或者多個值。

元組通常包含錯誤字符串,錯誤數(shù)字,錯誤位置。

實例
以下為單個異常的實例:

#!/usr/bin/python
# -*- coding: UTF-8 -*-

# 定義函數(shù)
def temp_convert(var):
    try:
        return int(var)
    except ValueError, Argument:
        print "參數(shù)沒有包含數(shù)字\n", Argument

# 調(diào)用函數(shù)
temp_convert("xyz");
以上程序執(zhí)行結(jié)果如下:

$ python test.py
參數(shù)沒有包含數(shù)字
invalid literal for int() with base 10: 'xyz'
觸發(fā)異常
我們可以使用raise語句自己觸發(fā)異常

raise語法格式如下:

raise [Exception [, args [, traceback]]]
語句中Exception是異常的類型(例如,NameError)參數(shù)是一個異常參數(shù)值。該參數(shù)是可選的,如果不提供,異常的參數(shù)是”None”。

最后一個參數(shù)是可選的(在實踐中很少使用),如果存在,是跟蹤異常對象。

實例
一個異??梢允且粋€字符串,類或?qū)ο蟆?Python的內(nèi)核提供的異常,大多數(shù)都是實例化的類,這是一個類的實例的參數(shù)。

定義一個異常非常簡單,如下所示:

def functionName( level ):
    if level < 1:
        raise Exception("Invalid level!", level)
        # 觸發(fā)異常后,后面的代碼就不會再執(zhí)行
注意:為了能夠捕獲異常,”except”語句必須有用相同的異常來拋出類對象或者字符串。

例如我們捕獲以上異常,”except”語句如下所示:

try:
    正常邏輯
except "Invalid level!":
    觸發(fā)自定義異常    
else:
    其余代碼
實例
#!/usr/bin/python
# -*- coding: UTF-8 -*-

# 定義函數(shù)
def mye( level ):
    if level < 1:
        raise Exception("Invalid level!", level)
        # 觸發(fā)異常后,后面的代碼就不會再執(zhí)行

try:
    mye(0)                // 觸發(fā)異常
except "Invalid level!":
    print 1
else:
    print 2
執(zhí)行以上代碼,輸出結(jié)果為:

$ python test.py
Traceback (most recent call last):
  File "test.py", line 11, in <module>
    mye(0)
  File "test.py", line 7, in mye
    raise Exception("Invalid level!", level)
Exception: ('Invalid level!', 0)
用戶自定義異常

通過創(chuàng)建一個新的異常類,程序可以命名它們自己的異常。異常應(yīng)該是典型的繼承自Exception類,通過直接或間接的方式。

以下為與RuntimeError相關(guān)的實例,實例中創(chuàng)建了一個類,基類為RuntimeError,用于在異常觸發(fā)時輸出更多的信息。

在try語句塊中,用戶自定義的異常后執(zhí)行except塊語句,變量 e 是用于創(chuàng)建Networkerror類的實例。

class Networkerror(RuntimeError):
    def __init__(self, arg):
        self.args = arg
在你定義以上類后,你可以觸發(fā)該異常,如下所示:

try:
    raise Networkerror("Bad hostname")
except Networkerror,e:
    print e.args

數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個參數(shù)驗證碼對象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗服務(wù)器是否宕機 new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機 product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計時完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }