模块(module)
- 模块化,指的是将一个完整的程序分解成一个一个小的模块
- 通过模块组合,来搭建一个完整的程序
- 不采用模块化:统一将所有的代码编写在一个文件中
- 采用模块化:将程序分别编写到多个文件中
模块化优点:
1、方便开发
2、方便维护
3、模块可以复用!
模块创建
- 在Python中一个 .py 文件就是一个模块,要创建模块,实际上就是创建一个.py文件
- 注意:模块名要符合标识符的规范
- 在一个模块中引入外部模块的几种方式
(1) import 模块名 (模块名,就是python文件的名字,注意不要加上 .py)
(2) import 模块名 as 模块别名
- 可以引入同一个模块多次,但是模块的实例只有一个
- import可以在程序任意位置调用,但一般在开头调用
- 在每一个模块内部都有一个__name__属性,通过该属性可以获取到模块的名字
如:有模块test,获取名字可以这么做: print(test.__name__)
- __name__属性值为 __main__的模块是主模块,一个程序中只会有一个主模块
主模块:直接通过Python执行的模块(通过调用的模块不是主模块)
包(package)
- 包也是一个模块(复杂的模块)
- 当模块中代码过多时,或者一个模块需要被分解为多个模块时,就需要使用到包
- 普通的模块就是一个.py文件,而包是一个文件夹(用来装很多个小模块)
包中必须有一个__init__.py文件,这个文件中可以包含有包中的主要内容
- __pycache__ 是模块的缓存文件
python代码在执行前,需要先被解析器转换为机器码,然后再执行
所以在使用模块(包)时,也需要将模块的代码转换为机器码,再交由计算机执行
而为了提高程序运行的性能,python会在编译过一次以后,将代码保存到一个缓存文件中
这样下次加载这个模块(包)时,就不用再重新编译,而是直接加载缓存中编译好的机器码即可
Python标准库
在标准库中有很多强大的模块
- sys模块
- 提供了一些变量和函数,使得我们能获取到python解析器的信息
或者通过函数来操作python解析器
# 引入sys模块
import sys
# 用于返回模块的搜索路径,返回一个列表,列表的元素就是模块的搜索路径
# 模块执行时会依次根据这些路径去寻找(这些路径一般不要动)
sys.path
# 表示当前python运行的平台
sys.platform 如:win32 win64 等等
# 退出程序
sys.exit()
# 也可以加上附加消息,如: sys.exit('程序出现异常,结束!')
# 获取执行代码时,命令行中所包含的参数
# 该属性是列表,列表中保存了当前命令的所有参数
sys.argv
# 获取当前程序中引入的所有模块
# 该属性是字典,key是模块名字,value是模块对象
sys.modules
- pprint模块
# 上面sys.modules 返回的字典杂乱无章,如果我们需要看清楚一些,就需要对其进行简单格式化
import pprint
# pprint.pprint()是pprint模块中的一个函数
pprint.pprint(sys.modules) ---> 将输出一个格式比较好看的字典
- os模块
- 让我们可以对操作系统进行访问
import os
# 获取系统的环境变量
os.environ
# 格式化打印
import pprint
pprint.pprint(os.environ)
# 如果要查看特定的环境变量,如path,则
pprint.pprint(os.environ['path'])
# os.system() 用来执行操作系统的命令,如
os.system('dir') ---> 执行系统的dir命令,获取目录
os.system('notepas') ---> 创建记事本