1、什么是模块
逻辑上来说模块就是一组功能的集合,实质上一个模块就是一个包含了python定义和声明的文件,文件名就是模块名加上.py后缀
模块中可以定义函数、类、变量,模块里也可以包含可执行的代码
模块分类:python内置模块、第三方模块、自定义模块
2、模块的作用
模块让你能够有逻辑的阻止你的python代码
把相关的代码分配到一个模块里能让代码拥有更好的可读性,让人更容易读懂和维护
3、模块的导入
3.1 导入模块
示例如下:
import datetime
print(datetime.datetime.now())
3.2 导入多个模块
导入多个模块有两种写法
写法一:
import datetime
import os
import sys
写法二:
import os,sys,datetime
两种写法效果是一样的
3.3 重复导入一个模块
需要注意的是:一个模块在同一个namesapce中只会被导入一次,不管你执行了多少次import,这样可以防止导入模块被反复执行。
我们可以通过以下示例来测试下重复导入时实际的导入次数
现有模块module1.py
# file_name: module1.py
print("加载当前模块")
我们在相同路径下的module2.py中多次导入module1模块,预期是print("加载当前模块")只会打印一次
# file_name: module2.py
import module1.py
import module1.py
import module1.py
执行module2.py,结果如下:
加载当前模块
Process finished with exit code 0
3.4 模块重命名
在导入模块的时候还可以对模块进行重命名,从而方便我们使用,并且如果当前文件中存在同名的方法或者变量,也可以通过这种方式避免冲突
示例:
import datatime as date
print(date.datetime.now())
3.5 from ... import ...语句
基本用法:
from time import sleep
同样支持重命名:
from time import sleep as sl
for i in range(10):
sl(1)
print("第 %d 次输出" % i)
全量导入:
from time import *
这种导入方法比较消耗资源,一般不建议使用
3.6 import与 from ... import ...语句的区别
from ... import ...与直接import的区别是:
import语句的导入会新建一个namespace,将模块中的名称存放在该空间中
from import会将name1、 name2单个导入到当前的namespace中,既然是导入到当前的namespace中,那就可以直接拿来使用,而不是再添加模块名称
3.7 模块重读
如果from ... import ....导致了名称重读,则取后定义的那个
示例:
# file_name:module1.py
def order():
print("我是模块1的order方法")
在另一个模块中导入该模块的order方法,并在当前模块重写一个order同名的方法
# file_name: module2.py
from module1 import order
def order():
print("我是模块2的order方法")
oder()
这里引用order函数,会使用module2.py模块中的order函数
4、搜索路径
当解释器遇到import语句,如果模块在当前的搜索路径就会被导入,搜索路径是一个解释器会先进行搜索的所有目录的列表,如果想要导入某模块,需要将命令放在脚本的最顶端
当我们导入一个模块时,python解析器对模块的搜索顺序是:
1.当前目录
2.在环境变量PYTHONPATH下的每个目录
3.默认路径,在Unix下默认路径一般是/usr/local/lib/python模块搜索路径存储在system模块的sys.path变量中,变量里包含当前目录、PYTHONPATH和由安装过程决定的默认目录
PYTHONPATH变量:作为环境变量,PYTHONPATH由装在一个列表中的许多目录组成,PYTHONPATH的语法和shell变量PATH的一样。
在Windows系统,典型的PYTHONPATH如下:
set PYTHONPATH=c:\python27\lib;
在Unix系统,典型的PYTHONPATH如下:
set PYTHONPATH=c:\python27\lib;
5、dir()和reloads函数
dir()函数
一个排好序的字符串列表,内容是一个模块里定义过的名字
返回的列表容纳在了一个模块里定义的所有模块、变量和函数
reloads()函数
当一个模块被导入到一个脚本,模块顶层部分代码只会被执行一次
因此,如果想要重新执行模块里顶层部分的代码,可以使用reload()函数,该函数会重新导入之前导入过的模块,该方法常可以用来加载PYTHONPATH
6、包
在Python中包是一个层次分明的文件目录结构,他定义了一个由模块及子包,和子包下的子包及模块等组成的python应用环境
简单来说,包就是文件夹
包与模块小结:
模块和包最本质的作用是降低系统代码的复杂性,易于维护、扩展和管理代码工程
当我们写的代码越来越多的时候,将所有的代码放入同一个.py文件中会显得难以维护,解决办法则是代码拆分入不同的.py文件中,
形成不同的模块,这样做还可以使同名变量互不影响,需要注意的是,模块不应与系统内置的函数重名
同时,不同的.py文件也可能同名,这时候就可以考虑将其放入不同的文件夹中,形成不同的包,防止同名模块的影响
在python中一个文件可以看做一个独立模块,而包对应着文件夹,模块把python代码分成一些有组织的代码段,通过导入的方式实现代码重用
包将有联系的模块阻止在一起,有效避免模块名称冲突问题,让应用组织结构更清晰,区别包和文件夹的重要特征就是包文件夹内
每一层目录都有初始化文件init.py