欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

python錯(cuò)誤處理:try..except..finally/logging/raise

python錯(cuò)誤繼承表:

10余年的藍(lán)山網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。全網(wǎng)整合營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整藍(lán)山建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)建站從事“藍(lán)山網(wǎng)站設(shè)計(jì)”,“藍(lán)山網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。

https://docs.python.org/3/library/exceptions.html#exception-hierarchy

格式:

def 函數(shù)():

      try:  

             內(nèi)容        ###正確輸出

      except 錯(cuò)誤表  in e:

              輸出內(nèi)容 ###錯(cuò)誤輸出

       finally:  

               輸出內(nèi)容   ##必定輸出

print('END')        ##必定輸出

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

def foo(s):
    return 10 / int(s)

def bar(s):
    return foo(s) * 2

def main():
    try:
        bar('0')
    except Exception as e:
        print('Error:', e)
    finally:
        print('finally...')

        
main()

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

('Error:', ZeroDivisionError('integer division or modulo by zero',))
finally...

a.面對(duì)函數(shù)層層調(diào)用,try...except能捕捉得到。

b.類的子類錯(cuò)誤也能捕捉得到,如捕捉ValueError錯(cuò)誤,順便也會(huì)把UnicodeError也捕捉了

 +-- ValueError
      |    +-- UnicodeError
      |         +-- UnicodeDecodeError
      |         +-- UnicodeEncodeError
      |         +-- UnicodeTranslateError

記錄錯(cuò)誤到日志文件:

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

import logging ###########記得導(dǎo)入模塊

def foo(s):
    return 10 / int(s)

def bar(s):
    return foo(s) * 2

def main():
    try:
        bar('0')
    except Exception as e:
        logging.exception(e) #########模塊函數(shù)使用
        
print ('haha')        
main()
print ('END')

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

haha
END


ERROR:root:division by zero
Traceback (most recent call last):
  File "/usercode/file.py", line 14, in main
    bar('0')
  File "/usercode/file.py", line 10, in bar
    return foo(s) * 2
  File "/usercode/file.py", line 7, in foo
    return 10 / int(s)
ZeroDivisionError: division by zero

當(dāng)不用錯(cuò)誤調(diào)試時(shí),普通的程序出錯(cuò)會(huì)調(diào)用棧Traceback提示錯(cuò)誤

def foo(s):
    return 10 / int(s)

def bar(s):
    return foo(s) * 2

def main():
    bar('0')

main()

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

Traceback (most recent call last):
  File "/usercode/file.py", line 13, in <module>
    main()
  File "/usercode/file.py", line 11, in main
    bar('0')
  File "/usercode/file.py", line 8, in bar
    return foo(s) * 2
  File "/usercode/file.py", line 5, in foo
    return 10 / int(s)
ZeroDivisionError: integer division or modulo by zero

拋出錯(cuò)誤:raise

def foo(s):
    n = int(s)
    if n==0:
        raise ValueError('invalid value: %s' % s)
    return 10 / n

def bar():
    try:
        foo('0')
    except ValueError as e:
        print('ValueError!', e)
        raise

bar()

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

('ValueError!', ValueError('invalid value: 0',))


Traceback (most recent call last):
  File "/usercode/file.py", line 17, in <module>
    bar()
  File "/usercode/file.py", line 12, in bar
    foo('0')
  File "/usercode/file.py", line 7, in foo
    raise ValueError('invalid value: %s' % s)
ValueError: invalid value: 0

文章標(biāo)題:python錯(cuò)誤處理:try..except..finally/logging/raise
鏈接分享:http://chinadenli.net/article46/gisdeg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、Google、手機(jī)網(wǎng)站建設(shè)、品牌網(wǎng)站制作、自適應(yīng)網(wǎng)站、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)