import模块/包--软件开发规范
一. 模块
模块:就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀。
import加载的模块分为四个通用类别:
1 使用python编写的代码(.py文件)
2 已被编译为共享库或DLL的C或C++扩展
3 包好一组模块的包
4 使用C编写并链接到python解释器的内置模块
import 语法:
导入一个模块相当于执行了这个被导入的文件
一个模块可以多次导入但不会被多次执行
导入一个模块的时候命名空间的变化
第一:创建了一块属于这个模块的命名空间
第二:创建了一个变量 指向这个命名空间
第三:执行这个文件
import time,os,random,my_module
模块虽然一行可以导入多个,但是不推荐这样使用
as语法:
import time as t
t.time()
time这个名字就失效的,只剩下t了
from import 语法:
from time import time
time()
不管是import 还是from import
都是执行完整的那个被导入的文件
并且所有的文件的导入 都不会破坏模块中本身的命名空间
如果是import 模块名
那么是模块名 指向 整个文件的命名空间
如果是from 模块名 import 变量名
那么 是在本文件中创建了同名的变量名 指向模块中的变量值
导入多个变量,并且重命名
from my_module import a,b,read
from my_module import a as aa,b as bb,read as r
print(a)
print(aa)
aa 和a都存在
from my_module import * # *表示导入模块中所有的变量和函数
# 可以在模块中使用__all__=['变量或方法'] 限制*导入的内容均为列里的变量或方法 但是指定导入变量或方法名不受影响
模块导入时的三个问题:
# 1 模块的搜索路径 import sys print(sys.path) #查看当前文件的系统路径 如果没有所要导的模块或包的路径 就无法正常导入 会提示:ModuleNotFoundError: No module named 'test3' sys.path.append(r'D:\PyCharmProject\s20\day26\demo') #将所要导的包或模块添加到系统路径 print(sys.path) import module1
# 模块之间的循环导入
# 在a.py import b
# 在b.py import a
#a.py
import b
aaa= '111'
print(aaa)
#b.py
import a
bbb =222
print(bbb)
'''
执行a.py的结果 #先导入b(这时执行b,b先执行导入a,执行a,但此时a已经执行过导入b.所以就不再执行这一步了,接着执行aaa,print(aaa)就到得了第一个答应结果
111 #然后返回b,接着执行bbb,print(bbb),得到第二个打印结果
222 #最后又返回a 接着执行aaa,print(aaa) 得到第三个打印结果
111
'''
#循环导入的时候如果提前调用导入模块中的变量或方法会报错
#a.py
import b
aaa= '111'
print(b.bbb)
#b.py
import a
bbb =222
print(a.aaa)
#执行a.py 会报错 AttributeError: module 'b' has no attribute 'bbb'
#这是因为循环导入时还没完成导入就开始调用b中内容当然就报错
#可以使用__name__ == '__main__'来避免这个错误
import b
aaa= '111'
if __name__ =='__main__':
print(b.bbb)
# 3 模块一旦被导入 再修改这个模块对应的文件也是不会生效的
import time
import my_module
print(my_module.a)
time.sleep(10) #在这期间去修改my_module中的变量并不会对目前这个导入生效
print(my_module.a)
import sys
print(sys.path)
二. 包的导入
包是一种通过使用‘.模块名’来组织python模块名称空间的方式。
1. 无论是import形式还是from...import形式,凡是在导入语句中(而不是在使用时)遇到带点的,都要第一时间提高警觉:这是关于包才有的导入语法
2. 包是目录级的(文件夹级),文件夹是用来组成py文件(包的本质就是一个包含__init__.py文件的目录)
3. import导入文件时,产生名称空间中的名字来源于文件,import 包,产生的名称空间的名字同样来源于文件,即包下的__init__.py,导入包本质就是在导入该文件
强调:
1. 在python3中,即使包下没有__init__.py文件,import 包仍然不会报错,而在python2中,包下一定要有该文件,否则import 包报错
2. 创建包的目的不是为了运行,而是被导入使用,记住,包只是模块的一种形式而已,包即模块
注意事项
1.关于包相关的导入语句也分为import和from ... import ...两种,但是无论哪种,无论在什么位置,在导入时都必须遵循一个原则:凡是在导入时带点的,点的左边都必须是一个包,否则非法。
可以带有一连串的点,如item.subitem.subsubitem,但都必须遵循这个原则。
(需要注意的是from后import导入的模块,必须是明确的一个不能带点,否则会有语法错误,如:from a import b.c是错误语法)
2.对于导入后,在使用时就没有这种限制了,点的左边可以是包,模块,函数,类(它们都可以用点的方式调用自己的属性)。
3.对比import item 和from item import name的应用场景:
如果我们想直接使用name那必须使用后者。
#import 导入
import glance.api.policy
glance.api.policy.get()
#from import导入 from glance.api import policy
policy.get()
from glance.api.policy import get
get()
使用from import import后面至少是精确到模块的
import后面不能有.
from后面可以有.,但是.的左边永远是包名
# 扩展内容: import一个包 这么包中的内容就都可以用了
import glance
#但是glanc目录下的__init__文件必须写:
'''
from glance import api
from glance import cmd
from glance import db
'''
print(glance)
print(glance.api)
print(glance.api.policy) glance.api.policy.get() #同理 api下的__init__写 from glance.api import policy
'''
<module 'glance' from 'D:\\飞秋下载\\feiq\\Recv Files\\day26\\glance\\__init__.py'>
<module 'glance.api' from 'D:\\飞秋下载\\feiq\\Recv Files\\day26\\glance\\api\\__init__.py'>
<module 'glance.api.policy' from 'D:\\飞秋下载\\feiq\\Recv Files\\day26\\glance\\api\\policy.py'>
from policy.py
'''
软件的开发规范:
# --项目名称
# -- bin 一个项目的启动文件装在这个文件夹下
# -- strat.py
# -- conf config配置,配置文件
# -- settings.py 可能会发生改变的配置信息
# -- core 核心代码
# -- 相关文件 实际的python代码所在的文件
# -- user.py
# -- auth.py
# -- main.py
# -- lib 库
# -- db database 数据库 一堆数据文件,不一定是py文件
# -- log 日志
# userinfo