动态导入模块
方式1(解释器调用)
根据当前目录结构进行动态导入模块设置
#在A1.py中
from code1 import aa #使用该方式就可以导入aa这个模块
#在A1.py中
modname = 'aa'
from code1 import modname
#如果通过导入字符串的方式,来导入模块就会报错,因为modname = 'aa',只是一个字符串形式,不是一个模块
#在A1.py中
mod1 = __import__('code1') #当前只导入了code1这个路径
mod2 = __import__('code1.aa') #这里虽然写的是'code1.aa',但是导入的也只是code1这个路径
print (mod1)
print (mod2)
执行结果:
<module 'code1' from 'E:\\python\\代码练习\\code1\\__init__.py'>
<module 'code1' from 'E:\\python\\代码练习\\code1\\__init__.py'>
#当前结果我们看到的虽然一样,但实际是有区别的;
mod1 = __import__('code1') #当前只导入了code1这个路径
mod2 = __import__('code1.aa') #这里虽然写的是'code1.aa',但是导入的只是code1这个路径
print (mod1.aa)
print (mod2.aa)
执行结果:
<module 'code1.aa' from 'E:\\python\\代码练习\\code1\\aa.py'>
<module 'code1.aa' from 'E:\\python\\代码练习\\code1\\aa.py'>
#在这里可能认为我们定义变量的时候(mod2 = __import__('code1.aa')),是否加后面的'.aa'都是可以的,但请看下面的代码
#将mod2注释掉
mod1 = __import__('code1')
print (mod1.aa)
执行结果:
Traceback (most recent call last):
File "E:/python/代码练习/A1.py", line 4, in <module>
print (mod1.aa)
AttributeError: module 'code1' has no attribute 'aa'
#可以看到单独的mod1是没有定义后面的'.aa',所以这里无法调用mod1.aa; 上面的代码能调用那是因为mod2中已经定义了'.aa',所以mod1才可以调用的。
#将mod1注释掉
mod2 = __import__('code1.aa')
print (mod2)
print (mod2.aa)
执行结果:
<module 'code1' from 'E:\\python\\代码练习\\code1\\__init__.py'>
<module 'code1.aa' from 'E:\\python\\代码练习\\code1\\aa.py'>
#执行结果说明了当定义了,假如只定义了2层路径时,第1层和第2层路径都是可以访问的,但是如果只定义了1层路径时,第2层路径是不能访问的(因为根本就不知道第2层路径的内容)。
#在aa.py中
class C:
def __init__(self):
self.name = 'zhangsan'
#在A1.py中
mod1 = __import__('code1.aa')
#这里虽然都是字符串格式,但却是可以通过__import__方式动态导入的
obj = mod1.aa.C() #对aa.py中的class C生成一个实例
print (obj.name)
执行结果:
zhangsan
方式2
官方建议使用方式2来动态导入模块
import importlib #内置模块
aa = importlib.import_module('code1.aa')
print (aa.C().name)
断言
断言可以判断是否为真
obj = 'zhangsan'
assert type(obj) is str
#通过type(obj)来判断obj是一个字符串;为真的话,就继续向下执行代码。
print ('testtest')
执行结果:
testtest
obj = 'zhangsan'
assert type(obj) is int #断言obj为整数
print ('testtest')
执行结果:
Traceback (most recent call last):
File "E:/python/代码练习/A2.py", line 4, in <module>
assert type(obj) is int
AssertionError
#断言错误,就不会向下执行代码
当后面的代码完全依赖前面的条件时,就可以使用断言;
比如判断一个变量为整数后,才对这个变量(整数)进行加减乘除的计算,否则就报错。
或者判断银行转账之前,得确认余额足够,然后才会去执行转账动作。
断言与if类似,不过断言会进行报错来提示。
转载于:https://blog.51cto.com/daimalaobing/2087347