我在b站学python之基础学习十八:模块

上一篇:我在b站学python之基础学习十七:异常

一、导入模块方式

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函数无法调用,因为没有添加到列表
上一篇:java4 -- SpringBoot定时任务调度


下一篇:(二)springboot整合之knife4j(详细)