目录
一、了解模块
Python模块,是一个Python文件,以.py结尾,包含了Python对象定义和Python语句。
模块能定义函数,类和变量,模块里也能包含可执行的代码。
二、导入模块的方式
1. import 模块名
- 语法
# 1.导入模块
import 模块名
# 2.调用功能
模块名.功能名()
快速体验:
import math
print(math.sqrt(16)) # 4.0
2. from 模块名 import 功能名
- 语法
# 1.导入模块
from 模块名 import 功能1,功能2,......
# 2.调用功能
功能名()
快速体验:
from math import sqrt
print(sqrt(16)) # 4.0
3. from 模块名 import *
- 语法
# 1.导入模块
from 模块名 import *
# 2.调用功能
功能名()
快速体验:
from math import *
print(sqrt(16)) # 4.0
4. as 别名
- 语法
# 模块定义别名
import 模块名 as 别名
# 功能定义别名
from 模块名 import 功能 as 别名
# 模块别名
import time as t1
t1.sleep(2)
print('Hello') # 2s之后,打印hello
# 调用功能
from time import sleep as s1
s1(3)
print('hello') # 3s之后,打印hello
三、制作模块
在Python中,每个Python文件都可以作为一个模块,模块的名字就是文件的名字。也就是说自定义模块名必须要符合标识符命名规则。
1. 定义模块
模块就是一个Python文件。
# 需求:新建一个python文件,my_module1.py,在这个模块里定义一个函数testA
def testA(a,b):
print(a + b)
"""
测试模块:
只在当前文件中调用该函数,其他导入的文件内不符合该条件,不执行下面的代码
这个的作用是:开发人员编写完成一个模块后,为了测试这个模块能达到想要的效果,而写的一些代码信息,只是用来测试的。这段代码只在当前文件中才会执行。
__name__是系统变量,是模块的标识符。
"""
if __name__ == '__main__':
testA(10,20)
2. 调用模块
# 需求:新建一个python文件,调用上一步制作的模块,验证都能调用成功。
# 1. 导入自己制作的模块
import my_module1
# 调用功能
my_module1.testA(100,200) # 300
3. 模块定位顺序
当导入一个模块,Python解释器对模块位置的搜索顺序是:
① 当前模块
② 如果不在当前目录,Python则搜索shell变量PYTHONPATH下的每个目录。
③ 如果都找不到,Python会查看默认路径,UNIX下,默认路径一般为/usr/local/lib/python/
模块搜索路径存储在system模块的sys.path变量中。变量里包含当前目录,PYTHONPATH和由安装过程决定的默认目录。
注意:
- 自己的文件名不要和已有模块名重复,否则导致模块功能无法使用。
- 使用from 模块名 import 功能的时候,如果功能名字重复,调用到的是最后定义或导入的功能。
四、__all__
如果一个模块文件中有__all__变量,当使用from 模块名 import * 导入时,只能导入这个列表中的元素。
- my_module1模块代码
# 定义多个功能,把某个功能添加到__all__
# 定义all列表
__all__ = ['testA']
def testA():
print('测试A')
def testB():
print('测试B')
- 导入模块代码
from my_module1 import *
testA() # 测试A
testB() # testB函数不能调用,因为testB函数没有添加到all列表,只有all列表里面的功能才能导入