Python模块 包
程序喵正在路上 人气:0模块
Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和 Python 语句
模块能定义函数,类和变量,模块里也能包含可执行的代码
1. 导入模块的方式
- import 模块名
- from 模块名 import 功能名
- from 模块名 import *
- import 模块名 as 别名
- from 模块名 import 功能名 as 别名
2. 导入方式详解
import
语法
# 1. 导入模块 import 模块名 import 模块名1,模块名2 # 2. 调用功能 模块名.功能名()
体验
import math print(math.sqrt(9)) # 3.0
from…import…
语法
from 模块名 import 功能1,功能2,功能3...
体验
from math import sqrt print(sqrt(9))
from… import *
语法
from 模块名 import *
体验
from math import * print(sqrt(9))
as定义别名
语法
# 模块定义别名 import 模块名 as 别名 # 功能定义别名 from 模块名 import 功能 as 别名
体验
# 模块别名 import time as tt tt.sleep(2) print('hello') # 功能别名 from time import sleep as sl sl(2) print('hello')
注意:定义别名后不能再使用原功能名
3. 制作模块
在 Python 中,每个 Python 文件都可以作为一个模块,模块的名字就是文件的名字,也就是说自定义模块名必须要符合标识符命名规则
① 定义模块
新建一个 Python 文件,命名为 my_module1.py,并定义 testA 函数
def testA(a, b): print(a + b)
② 测试模块
在实际开发中,当一个开发人员编写完一个模块后,为了让模块能够在项目中达到想要的效果,这个开发人员会自行在 py 文件中添加一些测试信息,例如,在 my_module1.py 文件中添加以下测试代码
def testA(a, b): print(a + b) # 测试信息 testA(1, 1)
此时,无论是当前文件,还是其他已经导入了该模块的文件,在运行的时候都会自动执行 testA 函数的调用
解决方法如下:
def testA(a, b): print(a + b) # 只在当前文件中调用该函数,其他导入的文件内不符合该条件,则不执行 testA 函数调用 # __name__ 是系统变量,是模块的标识符,值是:如果是自身模块值的 __main__,否则的当前模块名字 if __name__ == '__main__': testA(1, 1)
③ 调用模块
import my_module1 my_module1.testA(2,4)
4. 模块定位顺序
当导入一个模块,Python 解析器对模块位置的搜索顺序是:
- 当前目录
- 如果不在当前目录,Python 则搜索在 shell 变量 PYTHONPATH 下的每个目录
- 如果都找不到,Python 会查看默认路径。UNIX 下,默认路径一半为 /usr/local/lib/python/
模块搜索路径存储在 system 模块的 sys.path 变量中,变量里包含当前目录、PYTHONPATH 和由安装过程决定的默认目录
注意
◦ 自己的文件名不要和已有模块名重复,否则导致模块功能无法使用
◦ 使用 from 模块名 import 功能 的时候,如果功能名字重复,调用到的是最后定义或导入的功能
5. __all__
如果一个模块文件由 __all__ 变量,当使用 from xx import * 导入时,只能导入这个列表中的元素
my_module2 模块代码
__all__ = ['testA'] def testA(): print('testA') def testB(): print('testB')
导入模块的文件代码
from my_module2 import * testA() testB()
包
包将有联系的模块组织在一起,即放到同一个文件夹下,并且在这个文件夹创建一个名字为 __init__.py 文件,那么这个文件夹就称之为包
1. 制作包
[New] - [Python Package] - 输入包名 - [OK] - 新建功能模块(有联系的模块)
注意:新建包后,包内部会自动创建 __init__.py 文件,这个文件控制着包的导入行为
快速体验
- 新建包 my_package
- 新建包内模块:my_module1 和 my_module2
- 模块内代码如下
# my_module1 print(1) def info_print1(): print('my_module1')
# my_module1 print(2) def info_print2(): print('my_module2')
2. 导入包
方法一
import 包名.模块名
包名.模块名.目标
体验
import my_package.my_module1 my_package.my_module1.info_print1()
方法二
注意:必须在 __init__.py 文件中添加 __all__ = [],控制允许导入的模块列表
from 包名 import *
模块名.目标
体验
from my_package import * my_module1.info_print1()
总结
导入模块方法
import 模块名 from 模块名 import 目标 from 模块名 import *
导入包
import 包名.模块名 from 包名 import *
__all__ = []:允许导入的模块或功能列表
加载全部内容