自定义模块
定义:一个文件就是一个模块(能被调用的文件,模块就是一个工具箱,工具就是函数)
-
作用:
- 将代码文家化管理,提高可读性,避免重复代码
- 拿来就用(避免重复造*),python中类库比较多,提升开发效率
-
import导入时会做三件事:
# import test # 只能将整个工具箱拿来
# a = test.t1
# b = test.t2
#
# a()
# b()- 将.py文件中的所有代码读取到当前文件
- 在当前文件开辟空间
- 等待被调用
import导入同一个模块名时,只执行一次
import 和from 文件名较长时,都可以用as起别名,目的是为了防止内置模块名与自定义模块名重复,自定义模块会覆盖内置模块
导入模块名时后面不能加后缀
每个模块都有一个独立的内存空间,理论上是全局空间
-
from :推荐使用from
# from test import t1 as t # 从test工具箱中将t1这个工具拿过来
#
# def t1():
# print("高级工程师")
# t1() -
import 和 from的区别:
- from只能执行导入的工具
- import能后执行整个模块中所有的功能
- from容易将当前文件中定义的功能覆盖
- from 比import灵活
import只能导入当前文件夹下的模块
import 后边不能加点操作 ***
import 和 from 使用的都是相对路径
飘红不代表报错
-
sys:和python解释器交互的接口
- sys.path.append(r"被导入的模块路径")
- 内存 > 内置 > 第三方> 自定义
- sys.path.insert(0.r"被导入的模块路径")
- 内存 > 自定义 > 内置 > 第三方
- sys.path.append(r"被导入的模块路径")
-
模块的两种用法
- 当做模块导入:使用import 和 from, __ name __ 返回的是当前模块名
- 当作脚本执行:__ name __ 返回 ' __ main __'
只有py文件当做模块被导入时,字节码(pyc)才会进行保留
-
导入模块时遇到的坑:
- 注意自己的定义的模块名字与系统名字冲突
- 注意自己的思路---循环导入时建议导入模式放后边一点,需要的地方,不要互相查找内容
不建议一行导入多个
-
from test import * 意思是:拿整个工具箱过来
- 通过 __ all __ 控制要导入的内容
- __ all __ = ["a","func"] 控制 import *