一、模块
模块是一个python文件,以.py结尾,包含了python对象定义和python语句。模块能定义函数、类和变量,模块里也能包含可执行的代码
1.1导入模块
1.1.1导入模块的方式
import 模块名
from 模块名 import功能名
from 模块名 import*
import 模块名as别名
from 模块名 import功能名as别名
1.1.2导入模块详解
1.1.2.1import
#1、导入模块
import 模块名
#2、调用功能
模块名.功能名()
1.1.2.2from...import...
from模块名import功能1,功能2,功能3
from math import sqrt
print(sqrt(9))
1.1.2.3from 模块名 import*
from math import *
print(sqrt(9))
1.1.2.4as定义别名
#模块定义别名
import 模块名 as 别名
#功能定义别名
from 模块名 import 功能名 as 别名
1.2制作模块
每个python文件都可以作为一个模块,模块的名字就是文件的名字。也就是说自定义模块名必须要符合标识符命名规则
1.2.1定义模块
新建一个python文件,命名为my_module1.py,定义testA文件
def testA(a,b)
print(a+b)
测试testA文件
def testA(a,b)
print(a+b)
#__name__是系统变量,是模块的标识符,值是:如果是自身模块则是 __name_——,否则是当前模块的名字
if __name__ == '__main__':
testA(1,1)
调用模块
import my_module1
my_module1.testA(1,1)
1.3模块定位顺序
当导入一个模块,python解析器对模块位置的搜索顺序是:
1、当前目录
2、如果不在当前目录,python则搜索在shell变量PYTHONPATH的每个目录
3、如果都找不到,python会察看默认路径。UNIX下,默认路径一般为/usr/local/lib/python/模块搜索路径存储在system模块的sys.path变量中
注意;自己的文件名不要和已有的模块名重复,否则导致模块功能无法使用
使用from模块import功能名时,如果功能名字重复,调用到的是最后定义或导入的功能
1.4__all__
如果一个模块文件中有__all__变量,当使用from XXX import *导入时,只能导入这个列表中的元素
my_module1代码模块
__all__=['testA']
def testA():
print('testA')
def testB():
print('testB')
导入模块的文件代码
from my_module1 import *
testA()
testB()
二、包
包将有联系的模块组织在一起,即放在一个文件夹下,并且在这个文件夹创建一个名字为__init__.py文件,那么这个文件夹就叫包
2.1制作包
[New]--[Python Package]--输入包名--[OK]--新建功能模块(有联系的模块)
注意:新建包后,包内部会自动创建__init__.py文件,这个文件控制着包的导入行为
2.1.1快速体验
1、新建包mypackage
2、新建包内模块:my_module1和my_module2
3、模块内代码如下
#my_module1
print(1)
def info_print1():
print('my_module1')
#my_module2
print(2)
def info_print1():
print('my_module2')
2.2导入包
2.2.1法一
import 包名.模块名
包名.模块名.目标
体验
import my_package.my_module1
my_package.my_module1.info_print1()
2.2.2法二
注意:必须在__init__.py文件中添加__all__=[ ],控制允许导入的模块列表
from 包名 import *
模块名.目标
from my_package import *
my_module1.info_print1()