模块( module )和包( package )
模块:
引用模块的几种方式:
- import 模块名
- import 模块名 as 模块别名
- from 模块名 import 变量,变量 …
- from 模块名 import *
- from 模块名 import 变量 as 别名
方法3和5常用一些
首先创建一个模块文件 test_module.py:
# print('我是test_module模块')
# print(__name__)
a = 10
b = 20
# 添加了_的变量,只能在模块内部访问,在通过import * 引入时,不会引入_开头的变量
_c = 30
def test1():
print('我是test_modlue里的test1方法。')
class Person :
def __init__(self):
self.name = 'gdx'
# 开发编写模块的测试代码时,这部分代码,只有当前文件作为主模块时才需要执行
# 其他模块引入时,不需要执行
if __name__ == '__main__':
test1()
p = Person( )
print(p.name)
# 模块(module)
# 模块化指将一个完整的程序分解为一个一个小的模块
# 采用模块化将程序分别编写到多个文件中
# 模块化的优点:
# 1. 方便开发
# 2. 方便维护
# 3. 模块可以复用
# 在python中一个py文件就是一个模块,创建模块就是创建一个python文件
# 注意:文件名要符合标识符规范(只含有英文字母,数字和下划线,不以数字开头,不能是关键字,保留字)
# 在一个模块中引入外部模块:
# 1. import 模块名(即python文件的名字,注意不要.py)
# 2. import 模块名 as 模块别名
# - 可以引入同一个模块多次,但模块的实例只会创建一个
# - import可以在程序的任何位置调用,但一般情况下统一放在开头
# - 在每一个模块内部都有一个__name__属性,通过这个属性可以获取到模块的名字
# - __name__属性值为__main__的模块是主模块,一个程序中只有一个主模块
# 直接通过python执行的模块就是主模块
import test_module as t
print(t)
print(__name__)
print(t.__name__)
print('- '*40)
print( t.a , t.b )
t.test1()
p = t.Person()
print(p)
print(p.name)
# 只引入模块的部分内容
# 语法:
# from 模块名 import 变量,变量 . . .
# 引入模块的所有内容:(一般情况不要使用)
# from 模块名 import *
# 为引入的变量起别名:
# from 模块名 import 变量 as 别名
def test1():
print('这是主模块的test1。')
from test_module import Person,a
print(a)
p = Person( )
print(p)
print(p.name)
from test_module import test1 as new_test1
test1( )
new_test1( )
from test_module import *
# print(_c) # NameError: name '_c' is not defined
# 无法访问_开头的变量,函数,类
包( package )
包就是一个模块的集合
__pycache__ 存放缓存文件
创建一个文件夹,文件夹里要包含一个__init__.py 文件和其他 .py 文件
# 包 Package
# 包也是一个模块
# 当我们模块中的代码过多时,或者一个模块需要被分解为多个模块,需要用到包
# 普通的模块就是一个py文件,而包是一个文件夹
# 包中必须要有一个__init__.py 这个文件,这个文件可以包含包中的主要内容
import package
print(package)
package.test()
from package import a,b
print(a.n,b.k)
# __pycache__ 是模块的缓存文件
# py代码在执行前,需要被解析器转换为机器码,然后执行
# 当第一次调用模块(包)时,编译的结果会保存到__pycache__的缓存文件中
# 下次再使用模块(包)时不用再次编译,直接加载缓存中的代码即可
__init__.py 文件
def test():
print('test')
__a__.py文件
n = 'Name'
__b__.py文件
k = 'Bool'