今日内容
1. 模块:模块的概念
2.导入的方式:import from import
3. 环境变量:sys.path
4. 导入模块的顺序
5. 循环导入:模块间互相导入
模块
常见的四种模块: module
1. 使用python所编写的 .py文件。
2. 把一系列模块组织到一起的文件夹(文件夹下有一个__init__.py文件,该文件夹就被称之为包)
3. 使用C编写并直接链接到python解释器的内置模块
4. 已被编译为共享库或DLL的或C++扩展
# 1. 什么是模块:一系列功能的集合体
# 2. 为什么会出现模块: 很多相似的功能,要统一管理,将这些功能放在一个文件中,该文件就是管理这些功能的集合体,我们命名为模块
# 3. 怎么使用模块: 在要使用模块功能的文件中导入模块:import 模块名 (模块名: 用来管理一系列功能的文件名)
# 4. 在那使用模块: 在所有要使用模块中功能的文件中导入并使用模块
导入模板完成的三件事
首次导入:
import 模块名
# 1. 将,被导入的模块编译形成对应的pyc文件
# 2. 进入模块,从上至下执行模块中的代码,将产生的所有名字存放在该模块文件的全局名称空间中
# 3. 在使用模块的文件中,产生一个与模块名(模块文件名)同名的名字,指向模块的全局名称空间
再次导入:
# 不再执行导入模块的前两步,会直接走第三步:在当前模块中产生一个名字,指向第一次导入在内存中产生的全局名称空间
起别名
import 模块名 as 别名
# 重点:导入一旦起别名,原模块名变量失效,本质只产生了别名变量指向模块文件的全局名称空间
模块的分类
# 环境变量:存放路径的list ,第一默认一定是当前执行文件所在的路径
import sys
# sys .path 就是环境变量
# 如果清空环境变量:所有导入就都将不能使用
sys. path. clear()
# 添加指定路径到环境变量
sys . path . append() # 添加
sys . path . insert() # 插入
导入模块的顺序
内存 > 内置 > sys.path (安装环境变量中路径的先后顺序逐一加载)
from...import 语句导入
# 导入完成的三件事
# 1. 将被导入的模块编译形成对应的pyc文件
# 2. 进入模块,从上至下执行模块中的代码,将产生的所有名字存放在该模块文件的全局名称空间中
# 3. 在导入模块的文件中形成(一个或者多个)名字指向模块全局名称空间中的(一个或者多个)具体名字
from 模块名 import 模块中的名字1,。。。模块中名字n
from 模块名 import 名字 as 别名
## form ... import 导入依赖环境变量,sys. path
from...import* 语法
# 模块中默认会添加__all__, 而__all__的功能,就是管理模块中能被*导入的变量们
# __all__可以自定义,自定义* 能导入的变量,__all__的list 中名字全部可以自定义
# 系统默认添加的__all__中不会纳入 以_开头的名字,
---所以默认在外界通过from...import *无法导入_开头的名字
---_开头的名字对from...import * 是隐藏的,然而指名道姓依然可以被外界导入使用
链式导入
如果定义三个模块:m1,m2,m3, 然后m1模块中导入m2, m2 模块中导入m3, 然后再创建一个ti文件,在t1 中调用m1,那么他的执行流程会变为:
在t1文件中执行m1,在执行m1的过程中会遇到导入的m2,会马上进入m2去执行m2,在m2中又会碰到导入的m3,会马上去执行m3,m3执行完毕后会返回m2中导入m3的语句,接着执行m2,m2执行完毕回到m1,依次类推,最后返回t1
# 然而在整个执行流程中,遇到任何模块的二次导入,都是直接引用内存中的名称空间,不会再次进入模块
循环导入
# 循环导入的问题点:名字没有产生就使用名字
# 解决循环导入:先产生名字,在导入模块
-----将会产生循环导入的模块,导入语法延后,-延后导入
# 问题
# m1,py
import m2
print(m2,y)
x = 666
# m2.py
import m1
print(m2,x)
y = 888
此处的print就会报错,因为在全局变量没有产生就开始打印。
# 解决办法
# m1,py
x = 666
import m2
print(m2,y)
# m2,py
y = 888
import m1
print(m2,x)
此处是把全局变量提到调用模块的前面,所以此处的print能找到对应变量。