一、导入模块方式
1、方法一:import…
(1)语法:
导入模块:import 模块名1,模块名2…
调用功能:模块名.功能名
(2)例:
import math
print(math.sqrt(9))
2、方法二:from…import …
(1)语法:
from 模块名 import 功能1,功能2,功能3…
(2)例:
from math import sqrt
print(sqrt(9))
注意:不需要书写模块名.功能
3、方法三:from …import *
(1)语法:
from 模块名 import *
(2)例:
from math import *
print(sqrt(9))
4、方法四:as定义别名
(1)语法:
模块定义别名:import 模块名 as 别名
功能定义别名:from 模块名 import 功能 as 别名
(2)例:
#模块别名
import time as tt
tt。sleep(2)
print('hello')
#功能别名
from time import sleep as sl
sl(2)
print('hello')
注意:定义别名后只能使用别名
二、制作模块
1、概念
每个python文件都可以作为一个模块,模块的名字就是文件的名字。也就是说自定义模块名必须要符合标识符命名规则。
2、定义模块
新建一个python文件,命名为my_module1.oy,并定义testA函数
def testA(a,b ):
print(a + b)
3、测试模块
(1)普通:在文件中添加测试代码
def testA(a,b ):
print(a + b)
testA(1, 1)
运行正常即为定义正确。
问题:此时,无论是当前文件,还是其他已经导入了该模块的文件,在运行的时候都会自动执行testA函数的调用。
(2)升级
def testA(a,b ):
print(a + b)
#只在当前文件中调用该函数,其他导入的文件内不符合该条件,则不执行testA函数调用
if _name_ == '_main_':
testA(1, 1)
注意:name_如果是在自己当前文件中,则运行取值为_main,否则为文件名。
4、调用模块
import my_module1
my_module1.testA(1, 1)
三、模块定位顺序
当导入一个模块,python解析器对模块位置的搜索顺序是:
1、当前目录
2、如果不在当前目录,python则搜索在shell变量PYTHONPATH下的每个目录
3、如果找不到,python会查看默认路径。
模块搜索路径存储在system模块的sys.path变量中。变量包含当前目录,PYTHONPATH和由安装过程决定的默认目录。
注意:
1、自己的文件名不要和已有的模块名重复,否则导致模块功能无法使用。
2、使用from 模块名 import 功能的时候,如果功能名字重复,调用到的是最后定义或导入的功能。
例:
#注意1
#在当前目录下创建random.py空文件,在当前文件运行代码
import random
num = random.randint(1,5)
print(num)
#结果会报错
#注意2
from time import sleep
#定义函数sleep
def sleep():
print('自定义')
sleep(2)
#运行结果错误,此时sleep为自定义函数,但为无参函数
四、名字重复的结果
import time
print(time)
time = 1
print(time)
#变量覆盖了模块功能。原因:python中数据通过引用传递
五、all列表
如果一个模块文件中有_all_变量,当使用from …import * 导入时,只能导入这个列表中的元素。
1、例:
my_module1模块代码
_all_ = ['testA']
def testA():
print('testA')
def testB():
print('testB')
导入模块的文件代码
from my_module1 import *
testA()
testB()
#结果testB函数无法调用,因为没有添加到列表