模块是最高级别的程序组织单元
定义变量需要用赋值语句,封装函数需要用def语句,封装类需要用class语句,但封装模块不需要任何语句。
之所以不用任何语句,是因为每一份单独的Python代码文件(后缀名是.py的文件)就是一个单独的模块
每一个单独的py文件,本质上都是一个模块。
模块:“.py”后缀的文件即模块
类:使用class语句封装一个模块
函数:使用def函数封装一个函数
变量:使用赋值语句赋值一个变量
建立模块,其实就是在主程序的py文件中,使用import语句导入其他py文件
import语句
使用import语句导入一个模块,最主要的目的并不是运行模块中的执行语句,而是为了利用模块中已经封装好的变量、函数、类。
要使用模块中的变量、函数、类,需要在使用时加上模块.的格式
main.py
import test # 导入test模块
print(test.a) # 使用“模块.变量”调用模块中的变量
test.hi() # 使用“模块.函数()”调用模块中的函数
A = test.Go2() # 使用“变量 = 模块.类()”实例化模块中的类
print(A.a) # 实例化后,不再需要“模块.”
A.do2() # 实例化后,不再需要“模块.”
test.py
a = '我是模块中的变量a'
def hi():
a = '我是函数里的变量a'
print('函数“hi”已经运行!')
class Go2:
a = '我是类2中的变量a'
def do2(self):
print('函数“do2”已经运行!')
运行结果:
import语句还有一种用法是import…as…。比如我们觉得import story太长,就可以用import story as s 语句,意思是为“story”取个别名为“s”
from ... import ...
格式:
from (模块名) import (指定模块中的变量名/函数名/类名)
效果:
1.导入的模块中的指定部分(变量名/函数名/类名)
2.导入后的指定部分可以直接使用,无需加上"模块."前缀
# 【文件:test.py】
def hi():
print('函数“hi”已经运行!')
# 【文件:main.py】
from test import hi # 从模块test中导入函数“hi”
hi() # 使用函数“hi”时无需加上“模块.”前缀
from … import …语句要注意的是,没有被写在import后面的内容,将不会被导入
当我们需要从模块中指定所有内容直接使用时,可以写成【from xx模块 import *】的形式,*代表“模块中所有的变量、函数、类”,不过一般情况下不要为了图方便直接使用【from xx模块 import*】的形式,因为,模块.xx的调用形式能通过阅读代码一眼看出是在调用模块中的变量/函数/方法,而去掉模块.后代码就不是那么直观了。
if __name__ == '__main__'
当我们有了一大堆py文件组成一个程序的时候,为了【指明】某个py文件是程序的运行入口,我们可以在该py文件中写出这样的代码
# 【文件:xx.py】 代码块 ①…… if __name__ == '__main__': 代码块 ②……
意思是:1. 当xx.py文件被直接运行时,代码块②将被运行。2. 当xx.py文件作为模块被其他程序导入时,代码块②不被运行。
这里的【if __name__ == '__main__'】
就相当于是 Python 模拟的程序入口
自学模块:
学习模块的核心是搞清楚模块的功能,也就是模块中的函数和类方法有什么作用,以及具体使用案例长什么样,去网上搜教程,搜到教程后,我们重点关注的是模块中的函数和类方法有什么作用,然后把使用案例做成笔记
可以使用dir()函数查看一个模块,看看它里面有什么变量、函数、类、类方法
1.模块有哪些函数可用? 可以通过dir()函数查询
2.有哪些属性或方法可用? 去网上看文档或者教程
3.使用格式是什么? 从文档或教程中搜集案例
模块相关语句总结:
import语句
·使用“import(模块名)”导入模块
·可以使用“import(模块名) as (别名)” 为模块取别名
·导入模块后,在调用模块中的变量/函数/类的时候,要加上“模块名.”格式
from … import …语句
·from(模块名)import(指定的内容)
·导入模块,并且可以直接使用指定的内容(可以是变量、类、函数)
if __name__ == '__main__'
·通常在主模块中使用,表示这是“程序的入口”
·在该模块作为被导入的模块时,if __name__ == '__main__'后面的代码不会被运行