运行代码后即可生成笔记

未完成部分:

#代码如下

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 下执行”

接下来要执行的代码