本节摘要
一、模块导入
二、导入包
三、异常处理
一、模块导入
文件就是一个模块,文件夹就是一个包
文件夹里面可以有很多文件,就相当于包中有好多的模块.
1、import 引入
模块不会被重复导入,引入一次终生受益
importmymoduleimportmymodule#模块.变量
print(mymodule.cat)#模块.函数
mymodule.girl()#模块.类
obj =mymodule.ClassRoom()print(obj.name)
2、导入任意文件夹下的任意模块
importsysprint(sys.path)#在列表中追加一个新的目录,让系统自己寻找对应的文件
sys.path.append(r"D:\python33_gx\day15")importmymodule2print(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)引入包
importpackage1#包.成员
print(package1.boy)#init 文件中定义的或者在引入到init文件中
(2).引入包中的某个模块
importpackage1.mypath
package1.mypath.getsize()
起别名 asimportpackage1.mypath as pm
pm.join()##mypath 为包中的模块##getsize() join() 模块中方法
(3)类比os.path.join的使用方式
importpackage1
package1.mypath.join()## init文件中#通过初始化文件,引入mypath模块
from package1 import mypath
2.from ... import ..
(1)从包中引入具体成员
from package1 importsexprint(sex)#sex 在init文件中的变量
(2)从包中引入具体模块
from package1 importwangwen
wangwen.nianjing()##wangwen是包中模块#as用来起别名,简化名字
from package1.wangwen importclassflower 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 . importpkgone_210 print(pkgone_2.ceshi3)11
12 from .pkgone_2 importceshi413 print(ceshi4)14
15 from .. importpkg_116 print(pkg_1.ceshi100)17
18 from ..pkg_two importpkgtwo_119 print(pkgtwo_1.ceshi5)20
21 from ..pkg_two.pkgtwo_1 importceshi622 print(ceshi6)
pkgone_1.py
三、异常处理
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)
classMyClass():
a= 10MyClass.cccexceptIndexError:print("list out of range")exceptKeyError:print("KeyError: 'ccccc'")exceptNameError:print("NameError: name 'wangwen' is not defined")except:print("有异常错误 ....")
(3) StopIteration 捕捉到return返回值
1 defmygen():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 exceptStopIteration as e:18 #打印对象
19 #print(e) # 触发一
20 res = str(e) #触发二
21 print(res , type(res))22 res2 =eval(res)23 print(res2, type(res2))
View Code
(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:raiseRuntimeErrorexceptBaseException:print(3)
3.2抛出系统内置的异常错误类
1 #(了解)系统底层获取行数和文件名的函数( 只有在程序异常时才能触发 , 不报错,不触发)
2 defreturn_errorinfo(n):3 importsys4 f = sys.exc_info()[2].tb_frame.f_back5 if n==1:6 return str(f.f_lineno) #返回当前行数
7 elif n == 2:8 return f.f_code.co_filename #返回文件名
9
10 defget_info(n):11 try:12 raise
13 except:14 #接受错误的相关信息
15 returnreturn_errorinfo(n)16
17 classMyException(BaseException):18 def __init__(self,error_code,error_msg,error_file,error_line):19 #定义错误码
20 self.error_code =error_code21 #定义错误信息
22 self.error_msg =error_msg23 #定义错误文件
24 self.error_file =error_file25 #定义错误行号
26 self.error_line =error_line27
28 sex = "兽性"
29 try:30 if sex == "兽性":31 raise MyException(404,"人类是没有兽性的,除了李琦",get_info(2),get_info(1))32 exceptMyException 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
View Code