1. python如何自定義異常
8.5. 用戶自定義異常
在程序中可以通過創建新的異常類型來命名自己的異常(Python 類的內容請參見 類 )。異常類通常應該直接或間接的從 Exception 類派生,例如:
>>> class MyError(Exception):
... def __init__(self, value):
... self.value = value
... def __str__(self):
... return repr(self.value)
...
>>> try:
... raise MyError(2*2)
... except MyError as e:
... print('My exception occurred, value:', e.value)
...
My exception occurred, value: 4
>>> raise MyError('oops!')
Traceback (most recent call last):
File "
", line 1, in ?
__main__.MyError: 'oops!'
在這個例子中,Exception 默認的 __init__() 被覆蓋。新的方式簡單的創建 value 屬性。這就替換了原來創建 args 屬性的方式。
異常類中可以定義任何其它類中可以定義的東西,但是通常為了保持簡單,只在其中加入幾個屬性信息,以供異常處理句柄提取。如果一個新創建的模塊中需要拋出幾種不同的錯誤時,一個通常的作法是為該模塊定義一個異常基類,然後針對不同的錯誤類型派生出對應的異常子類:
class Error(Exception):
"""Base class for exceptions in this mole."""
pass
class InputError(Error):
"""Exception raised for errors in the input.
Attributes:
expression -- input expression in which the error occurred
message -- explanation of the error
"""
def __init__(self, expression, message):
self.expression = expression
self.message = message
class TransitionError(Error):
"""Raised when an operation attempts a state transition that's not
allowed.
Attributes:
previous -- state at beginning of transition
next -- attempted new state
message -- explanation of why the specific transition is not allowed
"""
def __init__(self, previous, next, message):
self.previous = previous
self.next = next
self.message = message
與標准異常相似,大多數異常的命名都以 「Error」 結尾。
很多標准模塊中都定義了自己的異常,用以報告在他們所定義的函數中可能發生的錯誤。
2. python except中的e是什麼意思
這個e是異常類的一個實例,如果我們完整地解釋這個問題,我覺得還是從Python的自定義異常類說起比較好。
假如,我們現在自定義一個簡單的異常類:
class MyError(Exception):
def __init__(self, value):
self.value = value
def __str__(self):
return repr(self.value)
我們拋這個異常的時候可以這么寫:
try:
raise MyError(2*2)
except MyError as e:
print 'My exception occurred, value:', e.value
我們在捕獲這個異常之後假如需要訪問TA的一些屬性怎麼辦,這個時候就可以使用as關鍵字
所以,這里的e是前面MyError類的一個instance,我們可以直接訪問他的value,也就是你看到的e.value
3. python初學者Traceback (most recent call last):
1、打開Python開發工具IDLE,新建『myexcept.py』文件,並寫代碼如下:
classmyException(Exception):
def__init__(self,error):
self.error=error
def__str__(self,*args,**kwargs):
returnself.error
這就是自定義定義的異常類,繼承自Exception父類,有error欄位,__str__函數的作用是列印對象時候,顯示的字元串。
4. python中用來拋出異常的關鍵字是
python中用來拋出異常的關鍵字是1.拋出異常和自定義異常 Python用異常對象(exception object)表
raise 語句 Python中的raise 關鍵字用於引發一個異常,基本上和C#和
自定義異常類型 Python中也可以自定義自己的特殊類型的異常,只需要要從Excepti
2.捕捉異常 和C#中的try/catch類似,Python中使用try/excep
5. 怎麼寫如果輸出有誤則輸出「輸入異常」的代碼
題目信息:命令行參數解析計算正方形周長、面積
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('--length', default = 10, type = float, help = '正方形邊長')
args = parser.parse_args()
area = args.length * args.length
girth = 4 * args.length
print('面積 = ',area, '周長 = ', girth)
測試結果:
PS D:\CodeProject\PyCharm\work1\lab6> python 6-1.py --length 3.2
面積 = 10.240000000000002 周長 = 12.8
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:命令行參數確認文件,讀取並輸出
import sys
filename = sys.argv[1]
f = open(filename, 'r', encoding = 'utf-8')
line_no = 0
while True:
line_no += 1
line = f.readline()
if line:
print(line_no, ":", line)
else:
break
f.close()
測試結果:
PS D:\CodeProject\PyCharm\work1\lab6> python 6-1.py C:\\Users\\JohnRothan\\Desktop\\test.txt
1 : Hello,World!
2 : Today is Friday.
3 : Let's do amazing things!
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:命令行參數確認文件,with語句讀取並輸出
import sys
filename = sys.argv[1]
line_no = 0
with open(filename, 'r', encoding = 'utf-8') as f:
for line in f:
line_no += 1
print(line_no, ":", line)
f.close()
測試結果:
PS D:\CodeProject\PyCharm\work1\lab6> python 6-1.py C:\\Users\\JohnRothan\\Desktop\\test.txt
1 : Hello,World!
2 : Today is Friday.
3 : Let's do amazing things!
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:利用with語句讀取並輸出文本文件,由命令行確認文件名
import sys
n = int(sys.argv[1])
power = 1
i = 0
f = open('D:\\CodeProject\\flex\\log.txt', 'w')
sys.stdout = f
while i <= n:
double = i * 2
print(str(i), '', str(double), '', str(power))
power = 2 * power
i = i + 1
sys.stdout = sys.__stdout__
print('done!')
測試結果:
0 0 1
1 2 2
2 4 4
3 6 8
4 8 16
5 10 32
#7.7 上機實踐-錯誤和異常
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:語法錯誤
print("Good Luck!"
print("幸運數:",random.choice(range(10)))
測試結果:
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 6
print("幸運數:",random.choice(range(10)))
^
SyntaxError: invalid syntax
錯誤處理:
print("Good Luck!")
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:運行時錯誤
print("Good Luck!")
print("幸運數:",random.choice(range(10)))
測試結果:
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 6, in <mole>
print("幸運數:",random.choice(range(10)))
NameError: name 'random' is not defined
錯誤處理:
import random
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:零除錯誤
a = 1
b = 0
c = a / b
測試結果:
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 7, in <mole>
c = a / b
ZeroDivisionError: division by zero
錯誤處理:
除數不能為0
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:邏輯錯誤
import math
a = 1; b = 2; c = 1
x1 = -b + math.sqrt(b*b - 4*a*c) / 2 * a
x2 = -b - math.sqrt(b*b - 4*a*c) / 2 * a
print(x1,x2)
測試結果:
-2.0 -2.0
錯誤處理:
一元二次方程計算公式錯誤,應修改為:
x1 = (-b + math.sqrt(b*b - 4*a*c)) / (2 * a)
x2 = (-b - math.sqrt(b*b - 4*a*c)) / (2 * a)
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:常見異常
noname
測試結果:變數未聲明
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 5, in <mole>
noname
NameError: name 'noname' is not defined
int a
測試結果:語法錯誤
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 5
int a
^
SyntaxError: invalid syntax
a = 1
a.show()
測試結果:show()函數未定義
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 6, in <mole>
a.show()
AttributeError: 'int' object has no attribute 'show'
11 + 'abc'
測試結果:類型錯誤
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 5, in <mole>
11 + 'abc'
TypeError: unsupported operand type(s) for +: 'int' and 'str'
int('abc')
測試結果:數值錯誤
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 5, in <mole>
int('abc')
ValueError: invalid literal for int() with base 10: 'abc'
1 / 0
測試結果:零除錯誤
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 5, in <mole>
1 / 0
ZeroDivisionError: division by zero
a = [10,11,12]
a[3]
測試結果:索引越界
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 6, in <mole>
a[3]
IndexError: list index out of range
m = {'1' : 'yes', '2' : 'no'}
m['3']
測試結果:字典關鍵字不存在
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 6, in <mole>
m['3']
KeyError: '3'
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:引發異常
a = input()
if a < 0: raise ValueError("不能為負!")
測試結果:
-2
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 5, in <mole>
if a < 0: raise ValueError("不能為負!")
TypeError: '<' not supported between instances of 'str' and 'int'
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:try-except-else-finally處理捕獲異常
try:
f = open("test.txt", 'w')
f.write("測試文件")
f1 = open('test1.txt', 'r')
except IOError:
print("沒有找到文件")
else:
print("寫入成功")
finally:
f.close()
測試結果:
沒有找到文件
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:處理異常
try:
f = open('mytxt.txt', 'w')
while True:
s = input("請輸入字元串(Q鍵結束):")
if s.upper() == 'Q' : break
f.write(s + '\n')
except KeyboardInterrupt:
print('程序中斷!(Ctrl-C)')
finally:
f.close()
測試結果:
請輸入字元串(Q鍵結束):cava
請輸入字元串(Q鍵結束):dcav
請輸入字元串(Q鍵結束):fe
請輸入字元串(Q鍵結束):4
請輸入字元串(Q鍵結束):Q
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:自定義異常類
class NumberError(Exception): #自定義異常類,繼承於Exception
def __init__(self,data):
Exception.__init__(self, data)
self.data = data
def __str__(self): #重載__str__方法
return self.data + ': 非法數值(< 0)'
def total(data):
total = 0
for i in data:
if i < 0: raise NumberError(str(i))
total += i
return total
#測試代碼
data1 = (44, 78, 90, 80, 55)
print('總計=', total(data1))
data2 = (44, 78, 90, -80, 55)
print('總計=', total(data2))
測試結果:
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 21, in <mole>
print('總計=', total(data2))
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 14, in total
if i < 0: raise NumberError(str(i))
__main__.NumberError: -80: 非法數值(< 0)
總計= 347
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:斷言
a = int(input("請輸入整數a:"))
b = int(input("請輸入整數b:"))
assert b != 0, '除數不能為0'
c = a / b
print(a, '/', b, '=', c)
測試結果:
請輸入整數a:1
請輸入整數b:0
Traceback (most recent call last):
File "D:\CodeProject\PyCharm\work1\lab6\6-1.py", line 7, in <mole>
assert b != 0, '除數不能為0'
AssertionError: 除數不能為0
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:輸出信息跟蹤邏輯錯誤調試:命令行參數分解為素數之積
import sys
n = int(sys.argv[1])
result=[]
factor = 2
while factor*factor <= n:
while (n % factor) == 0:
n //= factor
result.append(factor)
print(n, factor)
factor += 1
if n > 1:
result.append(n)
print(result)
測試結果:
PS D:\CodeProject\PyCharm\work1\lab6> python 6-1.py 1364
682 2
341 2
31 11
[2, 2, 11, 31]
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:默認配置直接輸出
import logging
logging.debug("調試信息") #不會輸出
logging.info("一般信息")
logging.warning("警告信息")
logging.error("錯誤信息")
logging.critical("嚴重錯誤")
測試結果:
WARNING:root:警告信息
ERROR:root:錯誤信息
CRITICAL:root:嚴重錯誤
# 作者:JohnRothan
# 時間:2022-4-22
# 題目信息:basicConfig配置輸出日誌到控制台
import logging
#配置logging
logging.basicConfig(level = logging.INFO
,format = '%(asctime)s - %(name)s - %(levelname)s - %(message)s')
#輸出日誌信息
logging.debug("調試信息") #不會輸出
logging.info("一般信息")
logging.warning("警告信息")
logging.error("錯誤信息")
logging.critical("嚴重錯誤")
測試結果:
2022-04-22 10:16:14,345 - root - INFO - 一般信息
2022-04-22 10:16:14,345 - root - WARNING - 警告信息
2022-04-22 10:16:14,345 - root - ERROR - 錯誤信息
2022-04-22 10:16:14,345 - root - CRITICAL - 嚴重錯誤
# 作者:JohnRothan
# 時間:2022-4-21
# 題目信息:basicConfig配置輸出日誌到文件和控制台
import logging
#配置logging
logger = logging.getLogger(__name__)
logger.setLevel(level=logging.DEBUG)
handler = logging.FileHandler("logging_console_file.txt")
handler.setLevel(logging.DEBUG)
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
handler.setFormatter(formatter)
console = logging.StreamHandler()
console.setLevel(logging.ERROR)
logger.addHandler(handler)
logger.addHandler(console)
#輸出日誌信息
logger.debug("調試信息")
logger.info("一般信息")
logger.warning("警告信息")
logger.error("錯誤信息")
logger.critical("嚴重錯誤")
測試結果:
控制台:
錯誤信息
嚴重錯誤
文件:
2022-04-22 10:18:41,783 - __main__ - DEBUG - 調試信息
2022-04-22 10:18:41,783 - __main__ - INFO - 一般信息
2022-04-22 10:18:41,783 - __main__ - WARNING - 警告信息
2022-04-22 10:18:41,783 - __main__ - ERROR - 錯誤信息
2022-04-22 10:18:41,783 - __main__ - CRITICAL - 嚴重錯誤
6. python中關於「 _,」的用法請教
python中的異常
異常是指程序中的例外,違例情況。異常機制是指程序出現錯誤後,程序的處理方法。當出現錯誤後,程序的執行流程發生改變,程序的控制權轉移到異常處理。
Exception類是常用的異常類,該類包括StandardError,StopIteration, GeneratorExit, Warning等異常類。
StandardError類是python中的錯誤異常,如果程序上出現邏輯錯誤, 將引發該異常。StandardError類是所有內斂異常的基類,放置在默認的命名空間中,因此使用IOEroor,
EOFError, ImportError等類,不需要導入exception模塊。
StopIteration類判斷循環是否執行到尾部,如果循環到尾部,則拋出該異常。
GeneratorExit類是由Generator函數引發的異常,當調用close()時引發該異常。
Warning類表示程序中的代碼引起的警告。
python中的異常使用繼承結構創建,可以在異常處理程序中捕獲基類異常,也可以捕獲各種子類異常,python中使用try...except語句捕獲異常,異常子句定義在try子句後面。
try...except的使用方法
try...except用於處理問題語句,捕獲可能出現的異常。try子句中的代碼塊放置可能出現異常的語句,except子句中的代碼塊處理異常。
演示try...except語句捕獲IOError異常
try:
file("hello.txt", "r") #如果文件不存在,引發異常
print "讀文件"
except IOError: #捕獲IO異常
print "文件不存在"
except: #其它異常
print "程序異常"
python與java的異常處理模式相似,異常處理語句也可以嵌套,演示如下:
try:
s = "hello"
try:
print s[0] + s[1]
print s[0] - s[1]
except TypeError:
print "字元串不支持減法運算"
except:
print "異常"
如果外層try子句中的代碼引發異常,程序將直接跳轉到外層try對應的except子句,而內部的try子句將不會被執行。
try...finally的使用方法
try...except後還可以添加一個finally子句。無論異常是否發生,finally子句都會被執行。所有的finally子句通常用於關閉因異常而不能釋放的系統資源。
try:
f = open("hello.txt", "r")
try:
print f.read(5)
except:
print "讀文件異常"
finally:
print "釋放資源"
f.close()
except IOError:
print "文件不存在"
使用raise拋出異常
當程序出現錯誤,python會自動引發異常,也可以通過raise顯示地引發異常。一旦執行了raise語句,raise後面的語句將不能執行。
演示raise用法
try:
s = None
if s is None:
print "s 是空對象"
raise NameError #如果引發NameError異常,後面的代碼將不能執行
print len(s)
except TypeError:
print "空對象沒有長度"
自定義異常
python允許程序員自定義異常,用於描述python中沒有涉及的異常情況,自定義異常必須繼承Exception類,自定義異常按照命名規范以"Error"結尾,顯示地告訴程序員這是異常。自定義異常使用raise語句引發,而且只能通過人工方式觸發。
from __future__ import division
class DivisionException(Exception):
def __init__(self, x, y):
Exception.__init__ (self, x, y) #調用基類的__init__進行初始化
self.x = x
self.y = y
if __name__ == "__main__":
try:
x = 3
y = 2
if x % y > 0: #如果大於0, 則不能被初始化,拋出異常
print x/y
raise DivisionException(x, y)
except DivisionException,div: #div 表示DivisionException的實例對象
print "DivisionExcetion: x/y = %.2f" % (div.x/div.y)
assert語句的使用
assert語句用於檢測某個條件表達式是否為真。assert語句又稱為斷言語句,即assert認為檢測的表達式永遠為真,if語句中的條件判斷都可以使用assert語句檢測。
7. python:定義一個Circle類,其中有求面積的方法,當半徑小於0時,拋出一個用戶自定義異常
//圓心坐標在此題中無用,是否是需求有問題。public class Circle { double x; double y; double r; double area; double length; public static void main(String[] args) { Circle c = new Circle(); c.setR(2); c.getArea(); c.getLength(); c.setXY(0, 0); } void setXY(double x, double y) { this.x = x; this.y = y; } void setR(double r) { this.r = r; } void getArea() { area = java.lang.Math.PI * r * r; } void getLength() { length = 2 * java.lang.Math.PI * r; }}
8. Python 異常處理總結
什麼是異常?
異常即是一個事件,該事件會在程序執行過程中發生,影響了程序的正常執行。一般情況下,在Python無法正常處理程序時就會發生一個異常。
異常是Python對象,表示一個錯誤。當Python腳本發生異常時我們需要捕獲處理它,否則程序會終止執行。
python提供了兩個非常重要的功能來處理python程序在運行中出現的異常和錯誤。你可以使用該功能來調試python程序。
異常處理: 本站Python教程會具體介紹。
斷言(Assertions):本站Python教程會具體介紹。
異常處理
捕捉異常可以使用try/except語句。try/except語句用來檢測try語句塊中的錯誤,從而讓except語句捕獲異常信息並處理。如果你不想在異常發生時結束你的程序,只需在try里捕獲它。
語法:
以下為簡單的try….except…else的語法:
try的工作原理是,當開始一個try語句後,python就在當前程序的上下文中作標記,這樣當異常出現時就可以回到這里,try子句先執行,接下來會發生什麼依賴於執行時是否出現異常。
· 如果當try後的語句執行時發生異常,python就跳回到try並執行第一個匹配該異常的except子句,異常處理完畢,控制流就通過整個try語句(除非在處理異常時又引發新的異常)。
· 如果在try後的語句里發生了異常,卻沒有匹配的except子句,異常將被遞交到上層的try,或者到程序的最上層(這樣將結束程序,並列印預設的出錯信息)。
· 如果在try子句執行時沒有發生異常,python將執行else語句後的語句(如果有else的話),然後控制流通過整個try語句。
實例
下面是簡單的例子,它打開一個文件,在該文件中的內容寫入內容,且並未發生異常:
以上程序輸出結果:
實例
下面是簡單的例子,它打開一個文件,在該文件中的內容寫入內容,但文件沒有寫入許可權,發生了異常:
以上程序輸出結果:
使用except而不帶任何異常類型
你可以不帶任何異常類型使用except,如下實例:
以上方式try-except語句捕獲所有發生的異常。但這不是一個很好的方式,我們不能通過該程序識別出具體的異常信息。因為它捕獲所有的異常。
使用except而帶多種異常類型
你也可以使用相同的except語句來處理多個異常信息,如下所示:
try-finally 語句
try-finally 語句無論是否發生異常都將執行最後的代碼。
實例
如果打開的文件沒有可寫許可權,輸出如下所示:
同樣的例子也可以寫成如下方式:
當在try塊中拋出一個異常,立即執行finally塊代碼。finally塊中的所有語句執行後,異常被再次提出,並執行except塊代碼。參數的內容不同於異常。
異常的參數
一個異常可以帶上參數,可作為輸出的異常信息參數。你可以通過except語句來捕獲異常的參數,如下所示:
變數接收的異常值通常包含在異常的語句中。在元組的表單中變數可以接收一個或者多個值。
元組通常包含錯誤字元串,錯誤數字,錯誤位置。
實例
以下為單個異常的實例:
以上程序執行結果如下:
觸發異常
我們可以使用raise語句自己觸發異常
raise語法格式如下:
語句中Exception是異常的類型(例如,NameError)參數是一個異常參數值。該參數是可選的,如果不提供,異常的參數是」None」。
最後一個參數是可選的(在實踐中很少使用),如果存在,是跟蹤異常對象。
實例
一個異常可以是一個字元串,類或對象。 Python的內核提供的異常,大多數都是實例化的類,這是一個類的實例的參數。
定義一個異常非常簡單,如下所示:
注意:為了能夠捕獲異常,」except」語句必須有用相同的異常來拋出類對象或者字元串。
例如我們捕獲以上異常,」except」語句如下所示:
用戶自定義異常
通過創建一個新的異常類,程序可以命名它們自己的異常。異常應該是典型的繼承自Exception類,通過直接或間接的方式。
以下為與RuntimeError相關的實例,實例中創建了一個類,基類為RuntimeError,用於在異常觸發時輸出更多的信息。
在try語句塊中,用戶自定義的異常後執行except塊語句,變數 e 是用於創建Networkerror類的實例。
在你定義以上類後,你可以觸發該異常,如下所示:
來源 | 腳本之家 原文鏈接:http://www.jb51.net/article/47996.htm
9. python中的異常類的認識理解
9.8. 異常也是類
用戶自定義異常也可以是類。利用這個機制可以創建可擴展的異常體系。
以下是兩種新的,有效的(語義上的)異常拋出形式,使用 raise 語句:
raise Class
raise Instance
第一種形式中,Class 必須是 type 或其派生類的一個實例。第二種形式是以下形式的簡寫:
raise Class()
發生的異常其類型如果是 except 子句中列出的類,或者是其派生類,那麼它們就是相符的(反過來說--發生的異常其類型如果是異常子句中列出的類的基類,它們就不相符)。例如,以下代碼會按順序列印 B,C,D:
class B(Exception):
pass
class C(B):
pass
class D(C):
pass
for cls in [B, C, D]:
try:
raise cls()
except D:
print("D")
except C:
print("C")
except B:
print("B")
要注意的是如果異常子句的順序顛倒過來( execpt B 在最前),它就會列印 B,B,B--第一個匹配的異常被觸發。
列印一個異常類的錯誤信息時,先列印類名,然後是一個空格、一個冒號,然後使用內置函數 str() 將類轉換得到的完整字元串。
10. Python中程序異常都能被處理嗎
「異常」是Python對象,表示一個錯誤。
如果不想出現異常後程序自動停止運行,編程的人,就要主動捕捉異常,並自己作出相應處理。
捕捉異常可以使用try/except語句。
try/except語句用來檢測try語句塊中的錯誤,從而讓except語句捕獲異常信息並處理。
下面是try/except的示例,說明了怎樣處理各種異常:
try:
<語句> #運行別的代碼
except <名字>:
<語句> #如果在try部份引發了'name'異常
except <名字>,<數據>:
<語句> #如果引發了'name'異常,獲得附加的數據
else:
<語句> #如果沒有異常發生
Python的各種標准異常是預先定義好的。基本上包括了常見的異常情況,主要有以下內容。
異常名稱 描述
BaseException 所有異常的基類
SystemExit 解釋器請求退出
KeyboardInterrupt 用戶中斷執行(通常是輸入^C)
Exception 常規錯誤的基類
StopIteration 迭代器沒有更多的值
GeneratorExit 生成器(generator)發生異常來通知退出
StandardError 所有的內建標准異常的基類
ArithmeticError 所有數值計算錯誤的基類
FloatingPointError 浮點計算錯誤
OverflowError 數值運算超出最大限制
ZeroDivisionError 除(或取模)零 (所有數據類型)
AssertionError 斷言語句失敗
AttributeError 對象沒有這個屬性
EOFError 沒有內建輸入,到達EOF 標記
EnvironmentError 操作系統錯誤的基類
IOError 輸入/輸出操作失敗
OSError 操作系統錯誤
WindowsError 系統調用失敗
ImportError 導入模塊/對象失敗
LookupError 無效數據查詢的基類
IndexError 序列中沒有此索引(index)
KeyError 映射中沒有這個鍵
MemoryError 內存溢出錯誤(對於Python 解釋器不是致命的)
NameError 未聲明/初始化對象 (沒有屬性)
UnboundLocalError 訪問未初始化的本地變數
ReferenceError 弱引用(Weak reference)試圖訪問已經垃圾回收了的對象
RuntimeError 一般的運行時錯誤
NotImplementedError 尚未實現的方法
SyntaxError Python 語法錯誤
IndentationError 縮進錯誤
TabError Tab 和空格混用
SystemError 一般的解釋器系統錯誤
TypeError 對類型無效的操作
ValueError 傳入無效的參數
UnicodeError Unicode 相關的錯誤
UnicodeDecodeError Unicode 解碼時的錯誤
UnicodeEncodeError Unicode 編碼時錯誤
UnicodeTranslateError Unicode 轉換時錯誤
Warning 警告的基類
DeprecationWarning 關於被棄用的特徵的警告
FutureWarning 關於構造將來語義會有改變的警告
OverflowWarning 舊的關於自動提升為長整型(long)的警告
PendingDeprecationWarning 關於特性將會被廢棄的警告
RuntimeWarning 可疑的運行時行為(runtime behavior)的警告
SyntaxWarning 可疑的語法的警告
UserWarning 用戶代碼生成的警告
Python系統處理異常就是提示一下,停止運行。不想停止,只有自己處理。
可以不帶類型,所有異常執行同一組語句:
try:
正常的操作
except:
發生異常,執行這塊代碼
else:
如果沒有異常執行這塊代碼
也可以多個異常共用一段代碼:
ry:
正常的操作
except(Exception1[, Exception2[,...ExceptionN]]]):
發生以上多個異常中的一個,執行這塊代碼
else:
如果沒有異常執行這塊代碼
還有一種格式,可以有finally部分:
try:
fh = open("testfile", "w")
try:
fh.write("這是一個測試文件,用於測試異常!!")
finally:
print "關閉文件"
fh.close()except IOError:
print "Error: 沒有找到文件或讀取文件失敗"
當在try塊中拋出一個異常,立即執行finally塊代碼。
finally塊中的所有語句執行後,異常被再次觸發,並執行except塊代碼。
參數的內容不同於異常。
除了標准異常,我們也可以自己定義異常,並進行處理,這時用到raise語句:
raise [Exception [, args [, traceback]]]
語句中 Exception 是異常的類型(例如,NameError)參數標准異常中任一種,args 是自已提供的異常參數。
最後一個參數是可選的(在實踐中很少使用),如果存在,是跟蹤異常對象。
相應的異常處理程序示例如下:
try:
正常語句,內含raise語句
except Exception,err:
觸發自定義異常
else:
其餘代碼