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

熱線電話:13121318867

登錄
首頁精彩閱讀Python中的異常處理相關語句基礎學習筆記
Python中的異常處理相關語句基礎學習筆記
2018-08-19
收藏

Python中的異常處理相關語句基礎學習筆記

這里我們簡單整理一下Python中的異常處理相關語句基礎學習筆記,包括try...except與assert等基本語句的用法講解:

異常是指因為程序出現(xiàn)了錯誤而在正??刂屏饕酝獠扇〉男袆樱浞譃閮蓚€階段,第一階段是引發(fā)異常的錯誤,當系統(tǒng)檢測到錯誤并且意識到異常條件,解釋器(也可以是程序員引發(fā)異常)會引發(fā)一個異常通知前段控制流有錯誤發(fā)生,對異常的處理發(fā)生在第二階段,異常引發(fā)后,可以調(diào)用很多不同的操作,可以是忽略錯誤,或是記錄錯誤但不采取任何措施,采取補救措施后終止程序,或是江青問題的影響后設法繼續(xù)執(zhí)行程序

類似Python這樣支持引發(fā)和處理異常的語言,可以讓開發(fā)人員在錯誤發(fā)生時不僅有檢測錯誤的能力,還可以采取更可靠的補救措施。
 Python用異常對象(exception object)來表示異常情況,遇到錯誤后,引發(fā)的異常如果未被處理或捕捉,程序會自動調(diào)用回溯(Traceback)終止執(zhí)行    
>>> 1/0
Traceback (most recent call last):
 File "", line 1, in
ZeroDivisionError: integer division or modulo by zero
>>>

 
python中的異常
python解釋器檢測的異常如:
1) NameError: 嘗試訪問一個未聲明的變量
2)ZeroDivisionError: 除數(shù)為零
3)SyntaxError:Python語法錯誤
4)IndexError: 請求的索引超出序列范圍
5)KeyError:請求一個不存在的字典關鍵字
6)IOError: 輸入/輸出錯誤
7)AttirbuteError: 嘗試訪問未知的對象屬性
8)TypeError:在內(nèi)建操作或者函數(shù) 應用于錯誤類型的對象時引發(fā)
9)ValueError: 在內(nèi)建操作或者函數(shù) 應用于正確類型的對象,但對該對象引用不合適的值引發(fā)
 
由程序員明確觸發(fā)異常:
raise語句:    
raise [someException [, args [, traceback]]]

 
檢測和處理異常
異??梢酝ㄟ^try語句來檢測,主要有兩種實現(xiàn)形式:try-except 和 try-finally:

try-except 語句
定義了進行異常監(jiān)控的一段代碼,并提供了處理異常的機制    
try:
  try_suite #進行監(jiān)控的代碼
except Exception[, reason]:
  except_suite #異常處理的代碼
[except Exception2[, reson2]:
  except_suite2 # 處理try語句中可能發(fā)生的多種異常
[else:
  else_suite #try中語句執(zhí)行沒有異常被檢測到
[finally:
  finally_suite #無論如何均會執(zhí)行]]]

 
try-finally語句
finally方式的語句并不是用來捕捉異常,而是用來維持一致的行為而無論異常是否發(fā)生,無論try中是否有異常觸發(fā),finally代碼段都會被執(zhí)行    
try:
  try:
    try_suite
  except:
    excetp_suite
finally:
  finally_suite

等效于:    
try:
  try_suite
except:
  excetp_suite
finally:
  finally_suite

Assert

Python中assert的運用于C語言中的assert()函數(shù)相似,
主要功能在于確保程序中的某個條件一定為真時,才能讓程序執(zhí)行,否則終止程序執(zhí)行并觸發(fā)AssertionError錯誤
其可以視為相對高級點的異常處理
語法:    
assert expression1, expression2

(不用小括號)
其中,expression1 表示程序繼續(xù)執(zhí)行的判斷條件,為真則繼續(xù),為假則程序終止,并拋出expression2給出的描述信息    
>>> a=10
>>> assert a<=10, "Error"
>>> a = 11
>>> assert a<=10, "Error"
Traceback (most recent call last):
 File "<stdin>", line 1, in <module>
AssertionError: Error

等價于:    
if a>10: raise AssertionError("Error")

說明:
assert語句一般用于程序編寫過程中的調(diào)試,將其添加到Python源代碼中后,未避免影響編譯性能,
建議盡量去除assert語句,并將__debug__這個內(nèi)置變量設置為False,即在運行命令行中添加參數(shù)    
python -0 test.py

(這其實與C語言中的編譯參數(shù)-d類似)

數(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)用相應的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗服務器是否宕機 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); }