我的python学习之路-异常处理和模块导入
本节摘要
一、模块导入
1.3 from .. import .. 从哪里导入什么什么东西
二、导入包
三、异常处理
一、模块导入
文件就是一个模块,文件夹就是一个包
文件夹里面可以有很多文件,就相当于包中有好多的模块.
1、import 引入
模块不会被重复导入,引入一次终生受益
import mymodule import mymodule # 模块.变量 print(mymodule.cat) # 模块.函数 mymodule.girl() # 模块.类 obj = mymodule.ClassRoom() print(obj.name)
2、导入任意文件夹下的任意模块
import sys print(sys.path) # 在列表中追加一个新的目录,让系统自己寻找对应的文件 sys.path.append(r"D:\python33_gx\day15") import mymodule2 print(mymodule2.ceshi1)
3、from .. import .. 从哪里导入什么什么东西
""" from mymodule import girl girl() """ # 导入多个成员 """ from mymodule import dog,boy print(dog) boy() """ # 导入所有成员 """ * 代表所有 """ """ from mymodule import * # print(dog) print(cat) boy() """
二、导入包
文件=>模块 文件夹=>包
当import 文件夹 时,会自动调用__init__.py初始化文件
1.import
(1)引入包
import package1 # 包.成员 print(package1.boy) # init 文件中定义的或者在引入到init文件中
(2).引入包中的某个模块
import package1.mypath package1.mypath.getsize() 起别名 as import package1.mypath as pm pm.join() ##mypath 为包中的模块 ##getsize() join() 模块中方法
(3)类比os.path.join的使用方式
import package1 package1.mypath.join() ## init文件中 # 通过初始化文件,引入mypath模块 from package1 import mypath
2.from ... import ..
(1)从包中引入具体成员
from package1 import sex print(sex) #sex 在init文件中的变量
(2)从包中引入具体模块
from package1 import wangwen wangwen.nianjing() ##wangwen是包中模块 # as用来起别名,简化名字 from package1.wangwen import classflower as c c()
(3)从包中->模块中-> 引入成员
from package1.wangwen import * classflower() # nianjing()
3.单入口模式(相对路径)
import package2.pkg_one.pkgone_1 as ppp1 # print(ppp1.ceshi1) ## pkg_one是包
1 """ 2 . 相对于当前 .. 相对于上一级 3 1.相对路径不能直接被执行,只有引入到主入口文件之后,会转化成绝对路径导入; 4 2.引入的落脚点落在模块或者模块中的具体成员身上; 5 """ 6 ceshi1 = 1 7 ceshi2 = 2 8 9 from . import pkgone_2 10 print(pkgone_2.ceshi3) 11 12 from .pkgone_2 import ceshi4 13 print(ceshi4) 14 15 from .. import pkg_1 16 print(pkg_1.ceshi100) 17 18 from ..pkg_two import pkgtwo_1 19 print(pkgtwo_1.ceshi5) 20 21 from ..pkg_two.pkgtwo_1 import ceshi6 22 print(ceshi6)
三、异常处理
1、异常分类
IndexError 索引超出序列的范围 KeyError 字典中查找一个不存在的关键字 NameError 尝试访问一个不存在的变量 IndentationError 缩进错误 AttributeError 尝试访问未知的对象属性 StopIteration 迭代器没有更多的值 AssertionError 断言语句(assert)失败 EOFError 用户输入文件末尾标志EOF(Ctrl+d) FloatingPointError 浮点计算错误 GeneratorExit generator.close()方法被调用的时候 ImportError 导入模块失败的时候 KeyboardInterrupt 用户输入中断键(Ctrl+c) MemoryError 内存溢出(可通过删除对象释放内存) NotImplementedError 尚未实现的方法 OSError 操作系统产生的异常(例如打开一个不存在的文件) OverflowError 数值运算超出最大限制 ReferenceError 弱引用(weak reference)试图访问一个已经被垃圾回收机制回收了的对象 RuntimeError 一般的运行时错误 SyntaxError Python的语法错误 TabError Tab和空格混合使用 SystemError Python编译器系统错误 SystemExit Python编译器进程被关闭 TypeError 不同类型间的无效操作 UnboundLocalError 访问一个未初始化的本地变量(NameError的子类) UnicodeError Unicode相关的错误(ValueError的子类) UnicodeEncodeError Unicode编码时的错误(UnicodeError的子类) UnicodeDecodeError Unicode解码时的错误(UnicodeError的子类) UnicodeTranslateError Unicode转换时的错误(UnicodeError的子类) ValueError 传入无效的参数 ZeroDivisionError 除数为零
2、异常处理-具体语法
try ... except ...
把所有可能错误的代码放到try代码块中,
如果报错,运行except这个代码块,反之不走
所有异常类的父类:BaseException
所有普通异常的父类:Exception
(1) 基本语法
try: lst = [1,2,3] print(lst[1000]) except: print("list out of range")
(2) 带有分支的异常处理
try: # lst = [1,2,3] # print(lst[1000]) # dic = {"a":1,"b":2} # print(dic["ccccc"]) # print(wangwen) class MyClass(): a = 10 MyClass.ccc except IndexError: print("list out of range") except KeyError: print("KeyError: 'ccccc'") except NameError: print("NameError: name 'wangwen' is not defined") except: print("有异常错误 .... ")
(3) StopIteration 捕捉到return返回值
1 def mygen(): 2 yield 1 3 yield 2 4 yield 3 5 return 8888 6 7 gen = mygen() 8 # for i in gen: 9 # pass 10 11 try: 12 print(next(gen)) 13 print(next(gen)) 14 print(next(gen)) 15 print(next(gen)) 16 # 给StopIteration类的对象起别名叫做e 17 except StopIteration as e: 18 # 打印对象 19 # print(e) # 触发一 20 res = str(e) # 触发二 21 print(res , type(res)) 22 res2 = eval(res) 23 print(res2, type(res2))
(4) 其他异常处理写法
1.try ... except ... else ...
总结:
如果运行的代码完全正确,执行else分支
如果运行的代码有错误,执行except分支
else分支 和 except分支 二选一;
2.try ... finally ...
总结: 无论代码是否有错误,都执行finally代码块;
比如文件操作;必须遇到close才能保存文件,但是一旦出现异常,必须在最后,执行一次数据保存
这样的代码写在finally代码块中
3、主动抛异常
语法: raise + 异常错误类/异常错误类对象
BaseException 所有异常类的父类
Exception 普通异常类的父类
print(issubclass(Exception,BaseException))
3.1抛出系统内置的异常错误类
# 抛出系统内置的异常错误类 # raise # raise RuntimeError # raise RuntimeError() # raise IndexError # raise KeyError # print(1) # 简写 try: raise except: print(2) # 完整写法 try: raise RuntimeError except BaseException: print(3)
3.2抛出系统内置的异常错误类
1 #(了解)系统底层获取行数和文件名的函数( 只有在程序异常时才能触发 , 不报错,不触发) 2 def return_errorinfo(n): 3 import sys 4 f = sys.exc_info()[2].tb_frame.f_back 5 if n==1: 6 return str(f.f_lineno) #返回当前行数 7 elif n == 2: 8 return f.f_code.co_filename #返回文件名 9 10 def get_info(n): 11 try: 12 raise 13 except: 14 # 接受错误的相关信息 15 return return_errorinfo(n) 16 17 class MyException(BaseException): 18 def __init__(self,error_code,error_msg,error_file,error_line): 19 # 定义错误码 20 self.error_code = error_code 21 # 定义错误信息 22 self.error_msg = error_msg 23 # 定义错误文件 24 self.error_file = error_file 25 # 定义错误行号 26 self.error_line = error_line 27 28 sex = "兽性" 29 try: 30 if sex == "兽性": 31 raise MyException(404,"人类是没有兽性的,除了李琦",get_info(2),get_info(1)) 32 except MyException as e: 33 print(e.error_code) # 404 34 print(e.error_msg) # 人类是没有兽性的,除了李琦 35 print(e.error_file) # /mnt/hgfs/python33_gx/day23/6.py 36 print(e.error_line) # 67