学习网址:https://www.runoob.com/python/python-basic-syntax.html
运行代码后即可生成笔记
未完成部分:
#代码如下:
import sys
# chapter20:Python3 错误和异常
print("\nchapter20:Python3 错误和异常\n")
print("1.概述")
print("1)Python 有两种错误很容易辨认:语法错误和异常。")
print("2)Python assert(断言)用于判断一个表达式,在表达式条件为 false 的时候触发异常。")
print("2.语法错误")
print("1)Python 的语法错误或者称之为解析错,是初学者经常碰到的")
print("2)语法分析器指出了出错的一行,并且在最先找到的错误的位置标记了一个小小的箭头。")
print("3.异常")
print("1)即便 Python 程序的语法是正确的,在运行它的时候,也有可能发生错误。运行期检测到的错误被称为异常。")
print("2)大多数的异常都不会被程序处理,都以错误信息的形式展现在这里:")
print("eg:")
print(">>>10 * (1/0) # 0 不能作为除数,触发异常\n"
"Traceback (most recent call last):\n"
" File \"<stdin>\", line 1, in ?\n"
"ZeroDivisionError: division by zero\n"
">>> 4 + spam*3 # spam 未定义,触发异常\n"
"Traceback (most recent call last):\n"
" File \"<stdin>\", line 1, in ?\n"
"NameError: name 'spam' is not defined\n"
">>> '2' + 2 # int 不能与 str 相加,触发异常\n"
"Traceback (most recent call last):\n"
" File \"<stdin>\", line 1, in ?\n"
"TypeError: Can't convert 'int' object to str implicitly")
print("3)异常以不同的类型出现,这些类型都作为信息的一部分打印出来: 例子中的类型有 ZeroDivisionError,NameError 和 TypeError。")
print("4)错误信息的前面部分显示了异常发生的上下文,并以调用栈的形式显示具体信息。")
print("4.异常处理")
print("1)try/except")
print("(1)异常捕捉可以使用 try/except 语句。")
print("eg:以下例子中,让用户输入一个合法的整数,但是允许用户中断这个程序(使用 Control-C 或者操作系统提供的方法)。用户中断的信息会引发一个 KeyboardInterrupt 异常。")
print("while True:\n"
" try:\n"
" x = int(input(\"请输入一个数字: \")) \n"
" break\n"
" except ValueError:\n"
" print(\"您输入的不是数字,请再次尝试输入!\")")
print("(2)try 语句按照如下方式工作;")
print("[1]首先,执行 try 子句(在关键字 try 和关键字 except 之间的语句)。\n"
"[2]如果没有异常发生,忽略 except 子句,try 子句执行后结束。\n"
"[3]如果在执行 try 子句的过程中发生了异常,那么 try 子句余下的部分将被忽略。如果异常的类型和 except 之后的名称相符,那么对应的 except 子句将被执行。\n"
"[4]如果一个异常没有与任何的 excep 匹配,那么这个异常将会传递给上层的 try 中。")
print("(3)一个 try 语句可能包含多个except子句,分别来处理不同的特定的异常。最多只有一个分支会被执行。")
print("(4)处理程序将只针对对应的 try 子句中的异常进行处理,而不是其他的 try 的处理程序中的异常。")
print("(5)一个except子句可以同时处理多个异常,这些异常将被放在一个括号里成为一个元组,例如:\n"
"except (RuntimeError, TypeError, NameError):\n"
" pass")
print("(6)最后一个except子句可以忽略异常的名称,它将被当作通配符使用。你可以使用这种方法打印一个错误信息,然后再次把异常抛出。")
print("eg:")
print("import sys\n"
"try:\n"
" f = open('myfile.txt')\n"
" s = f.readline()\n"
"except OSError as err:\n"
" print(\"OS error: {0}\".format(err))\n"
"except ValueError:\n"
" print(\"Could not convert data to an integer.\")\n"
"except:\n"
" print(\"Unexpected error:\", sys.exc_info()[0])\n"
" raise")
print("2)try/except...else")
print("(1)try/except 语句还有一个可选的 else 子句,如果使用这个子句,那么必须放在所有的 except 子句之后。else 子句将在 try 子句没有发生任何异常的时候执行。")
print("eg:以下实例在 try 语句中判断文件是否可以打开,如果打开文件时正常的没有发生异常则执行 else 部分的语句,读取文件内容:")
print("for arg in sys.argv[1:]:\n"
" try:\n"
" f = open(arg, 'r')\n"
" except IOError:\n"
" print('cannot open', arg)\n"
" else:\n"
" print(arg, 'has', len(f.readlines()), 'lines')\n"
" f.close()")
print("(2)使用 else 子句比把所有的语句都放在 try 子句里面要好,这样可以避免一些意想不到,而 except 又无法捕获的异常。")
print("(3)异常处理并不仅仅处理那些直接发生在 try 子句中的异常,而且还能处理子句中调用的函数(甚至间接调用的函数)里抛出的异常。")
print("eg:")
print(">>>def this_fails():\n"
" x = 1/0\n"
">>> try:\n"
" this_fails()\n"
" except ZeroDivisionError as err:\n"
" print('Handling run-time error:', err)\n"
"Handling run-time error: int division or modulo by zero")
print("3)try-finally 语句")
print("(1)try-finally 语句无论是否发生异常都将执行最后的代码。")
print("eg:以下实例中 finally 语句无论异常是否发生都会执行")
print("try:\n"
" runoob()\n"
"except AssertionError as error:\n"
" print(error)\n"
"else:\n"
" try:\n"
" with open('file.log') as file:\n"
" read_data = file.read()\n"
" except FileNotFoundError as fnf_error:\n"
" print(fnf_error)\n"
"finally:\n"
" print('这句话,无论异常是否发生都会执行。')")
print("5.抛出异常")
print("1)Python 使用 raise 语句抛出一个指定的异常。")
print("2)raise语法格式如下:\n"
"raise [Exception [, args [, traceback]]]")
print("eg:以下实例如果 x 大于 5 就触发异常:")
print("x = 10\n"
"if x > 5:\n"
" raise Exception('x 不能大于 5。x 的值为: {}'.format(x))")
print("\n执行以上代码会触发异常:")
print("Traceback (most recent call last):\n"
" File \"test.py\", line 3, in <module>\n"
" raise Exception('x 不能大于 5。x 的值为: {}'.format(x))\n"
"Exception: x 不能大于 5。x 的值为: 10")
print("3)raise 唯一的一个参数指定了要被抛出的异常。它必须是一个异常的实例或者是异常的类(也就是 Exception 的子类)。")
print("4)如果你只想知道这是否抛出了一个异常,并不想去处理它,那么一个简单的 raise 语句就可以再次把它抛出。")
print("eg:")
print(">>>try:\n"
" raise NameError('HiThere')\n"
" except NameError:\n"
" print('An exception flew by!')\n"
" raise\n"
"An exception flew by!\n"
"Traceback (most recent call last):\n"
" File \"<stdin>\", line 2, in ?\n"
"NameError: HiThere")
print("6.用户自定义异常")
print("1)你可以通过创建一个新的异常类来拥有自己的异常。异常类继承自 Exception 类,可以直接继承,或者间接继承")
print("eg:")
print(">>>class MyError(Exception):\n"
" def __init__(self, value):\n"
" self.value = value\n"
" def __str__(self):\n"
" return repr(self.value)\n"
">>> try:\n"
" raise MyError(2*2)\n"
" except MyError as e:\n"
" print('My exception occurred, value:', e.value)\n"
"My exception occurred, value: 4\n"
">>> raise MyError('oops!')\n"
"Traceback (most recent call last):\n"
" File \"<stdin>\", line 1, in ?\n"
"__main__.MyError: 'oops!'")
print("2)当创建一个模块有可能抛出多种不同的异常时,一种通常的做法是为这个包建立一个基础异常类,然后基于这个基础类为不同的错误情况创建不同的子类")
print("3)大多数的异常的名字都以\"Error\"结尾,就跟标准的异常命名一样。")
print("7.定义清理行为")
print("1)try 语句还有另外一个可选的子句,它定义了无论在任何情况下都会执行的清理行为。")
print("2)如果一个异常在 try 子句里(或者在 except 和 else 子句里)被抛出,而又没有任何的 except 把它截住,那么这个异常会在 finally 子句执行后被抛出。")
print("8.预定义的清理行为")
print("1)一些对象定义了标准的清理行为,无论系统是否成功的使用了它,一旦不需要它了,那么这个标准的清理行为就会执行。")
print("9.assert(断言)")
print("1)Python assert(断言)用于判断一个表达式,在表达式条件为 false 的时候触发异常。")
print("2)断言可以在条件不满足程序运行的情况下直接返回错误,而不必等待程序运行后出现崩溃的情况")
print("eg:")
print("我们的代码只能在 Linux 系统下运行,可以先判断当前系统是否符合条件。")
print("import sys\n"
"assert ('linux' in sys.platform), \"该代码只能在 Linux 下执行\"\n"
"# 接下来要执行的代码")
#代码执行结果如下:
chapter20:Python3 错误和异常
1.概述
1)Python 有两种错误很容易辨认:语法错误和异常。
2)Python assert(断言)用于判断一个表达式,在表达式条件为 false 的时候触发异常。
2.语法错误
1)Python 的语法错误或者称之为解析错,是初学者经常碰到的
2)语法分析器指出了出错的一行,并且在最先找到的错误的位置标记了一个小小的箭头。
3.异常
1)即便 Python 程序的语法是正确的,在运行它的时候,也有可能发生错误。运行期检测到的错误被称为异常。
2)大多数的异常都不会被程序处理,都以错误信息的形式展现在这里:
eg:
10 * (1/0) # 0 不能作为除数,触发异常
Traceback (most recent call last):
File “”, line 1, in ?
ZeroDivisionError: division by zero4 + spam*3 # spam 未定义,触发异常
Traceback (most recent call last):
File “”, line 1, in ?
NameError: name ‘spam’ is not defined‘2’ + 2 # int 不能与 str 相加,触发异常
Traceback (most recent call last):
File “”, line 1, in ?
TypeError: Can’t convert ‘int’ object to str implicitly
3)异常以不同的类型出现,这些类型都作为信息的一部分打印出来: 例子中的类型有 ZeroDivisionError,NameError 和 TypeError。
4)错误信息的前面部分显示了异常发生的上下文,并以调用栈的形式显示具体信息。
4.异常处理
1)try/except
(1)异常捕捉可以使用 try/except 语句。
eg:以下例子中,让用户输入一个合法的整数,但是允许用户中断这个程序(使用 Control-C 或者操作系统提供的方法)。用户中断的信息会引发一个 KeyboardInterrupt 异常。
while True:
try:
x = int(input("请输入一个数字: "))
break
except ValueError:
print(“您输入的不是数字,请再次尝试输入!”)
(2)try 语句按照如下方式工作;
[1]首先,执行 try 子句(在关键字 try 和关键字 except 之间的语句)。
[2]如果没有异常发生,忽略 except 子句,try 子句执行后结束。
[3]如果在执行 try 子句的过程中发生了异常,那么 try 子句余下的部分将被忽略。如果异常的类型和 except 之后的名称相符,那么对应的 except 子句将被执行。
[4]如果一个异常没有与任何的 excep 匹配,那么这个异常将会传递给上层的 try 中。
(3)一个 try 语句可能包含多个except子句,分别来处理不同的特定的异常。最多只有一个分支会被执行。
(4)处理程序将只针对对应的 try 子句中的异常进行处理,而不是其他的 try 的处理程序中的异常。
(5)一个except子句可以同时处理多个异常,这些异常将被放在一个括号里成为一个元组,例如:
except (RuntimeError, TypeError, NameError):
pass
(6)最后一个except子句可以忽略异常的名称,它将被当作通配符使用。你可以使用这种方法打印一个错误信息,然后再次把异常抛出。
eg:
import sys
try:
f = open(‘myfile.txt’)
s = f.readline()
except OSError as err:
print(“OS error: {0}”.format(err))
except ValueError:
print(“Could not convert data to an integer.”)
except:
print(“Unexpected error:”, sys.exc_info()[0])
raise
2)try/except…else
(1)try/except 语句还有一个可选的 else 子句,如果使用这个子句,那么必须放在所有的 except 子句之后。else 子句将在 try 子句没有发生任何异常的时候执行。
eg:以下实例在 try 语句中判断文件是否可以打开,如果打开文件时正常的没有发生异常则执行 else 部分的语句,读取文件内容:
for arg in sys.argv[1:]:
try:
f = open(arg, ‘r’)
except IOError:
print(‘cannot open’, arg)
else:
print(arg, ‘has’, len(f.readlines()), ‘lines’)
f.close()
(2)使用 else 子句比把所有的语句都放在 try 子句里面要好,这样可以避免一些意想不到,而 except 又无法捕获的异常。
(3)异常处理并不仅仅处理那些直接发生在 try 子句中的异常,而且还能处理子句中调用的函数(甚至间接调用的函数)里抛出的异常。
eg:def this_fails():
x = 1/0try:
this_fails()
except ZeroDivisionError as err:
print(‘Handling run-time error:’, err)
Handling run-time error: int division or modulo by zero
3)try-finally 语句
(1)try-finally 语句无论是否发生异常都将执行最后的代码。
eg:以下实例中 finally 语句无论异常是否发生都会执行
try:
runoob()
except AssertionError as error:
print(error)
else:
try:
with open(‘file.log’) as file:
read_data = file.read()
except FileNotFoundError as fnf_error:
print(fnf_error)
finally:
print(‘这句话,无论异常是否发生都会执行。’)
5.抛出异常
1)Python 使用 raise 语句抛出一个指定的异常。
2)raise语法格式如下:
raise [Exception [, args [, traceback]]]
eg:以下实例如果 x 大于 5 就触发异常:
x = 10
if x > 5:
raise Exception(‘x 不能大于 5。x 的值为: {}’.format(x))
执行以上代码会触发异常:
Traceback (most recent call last):
File “test.py”, line 3, in
raise Exception(‘x 不能大于 5。x 的值为: {}’.format(x))
Exception: x 不能大于 5。x 的值为: 10
3)raise 唯一的一个参数指定了要被抛出的异常。它必须是一个异常的实例或者是异常的类(也就是 Exception 的子类)。
4)如果你只想知道这是否抛出了一个异常,并不想去处理它,那么一个简单的 raise 语句就可以再次把它抛出。
eg:
try:
raise NameError(‘HiThere’)
except NameError:
print(‘An exception flew by!’)
raise
An exception flew by!
Traceback (most recent call last):
File “”, line 2, in ?
NameError: HiThere
6.用户自定义异常
1)你可以通过创建一个新的异常类来拥有自己的异常。异常类继承自 Exception 类,可以直接继承,或者间接继承
eg: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: 4raise MyError(‘oops!’)
Traceback (most recent call last):
File “”, line 1, in ?
main.MyError: ‘oops!’
2)当创建一个模块有可能抛出多种不同的异常时,一种通常的做法是为这个包建立一个基础异常类,然后基于这个基础类为不同的错误情况创建不同的子类
3)大多数的异常的名字都以"Error"结尾,就跟标准的异常命名一样。
7.定义清理行为
1)try 语句还有另外一个可选的子句,它定义了无论在任何情况下都会执行的清理行为。
2)如果一个异常在 try 子句里(或者在 except 和 else 子句里)被抛出,而又没有任何的 except 把它截住,那么这个异常会在 finally 子句执行后被抛出。
8.预定义的清理行为
1)一些对象定义了标准的清理行为,无论系统是否成功的使用了它,一旦不需要它了,那么这个标准的清理行为就会执行。
9.assert(断言)
1)Python assert(断言)用于判断一个表达式,在表达式条件为 false 的时候触发异常。
2)断言可以在条件不满足程序运行的情况下直接返回错误,而不必等待程序运行后出现崩溃的情况
eg:
我们的代码只能在 Linux 系统下运行,可以先判断当前系统是否符合条件。
import sys
assert (‘linux’ in sys.platform), “该代码只能在 Linux 下执行”