标签:实现 pycharm 应该 importlib 反射 ext 添加 找不到 循环
第三方模块/扩展模块:没在安装python解释器的时候安装的那些功能
自定义模块:你写的功能如果是一个通用的功能,那你就把它当做一个模块
内置模块:安装python解释器的时候跟着装上的那些方法
import my_module 要导入一个py文件的名字,但是不加.py后缀名
import my_module 模块的名字必须要满足变量的命名规范
一般情况下 模块都是小写字母开头的名字
所有的模块导入都应该尽量放在这个文件的开头
模块的导入也是有顺序的
先导入内置模块
再导入第三方模块
最后导入自定义模块
import 的时候发生了什么
在import的时候命名空间的变换
重命名 as
一行导入多个模块
from import 的时候发生了什么 仍然相当于执行了整个py文件
在import的时候命名空间的变换
重命名 as
一行导入多个名字 导入了什么 就能使用什么 不导入的变量 不能使用 不导入并不意味着不存 而是没有建立文件到模块中其他名字的引用
from 模块 import *
* 和 __all__ 的相关性 __all__可以控制*导入的内容
from my_module import * login() from my_module import name print(name)
if __name__ == ‘__main__‘:
所有不需要调用就能执行的内容
import sys getattr(sys.modules[__name__],‘要反射的变量名‘)
模块没导入之前在哪儿? 在硬盘上
安装python
python整个包的结构不变
它会记录一个安装目录
其他所有目录都是根据安装目录来写死的
除了你当前运行的脚本所在的目录和pycharm在你打开项目的时候给你添加进来的项目根目录
剩余所有都是python内置的目录
内置模块的导入
第三方模块的导入
内置模块的导入和第三方模块的导入都不需要你操心了
自定义的模块能否被导入
看sys.path当中 是否存在你要导入的文件 所在的目录
总结:
模块的搜索路径全部存储在sys.path列表中,导入模块的顺序,是从前到后找到一个符合条件的模块就立即停止不再向后寻找
如果要导入的模块和当前执行的文件同级,直接导入即可
如果要导入的模块和当前执行的文件不同级,需要把要导入模块的绝对路径添加到sys.path列表中
python的执行
解释 - 编译
当一个文件作为一个脚本被导入的时候
就会在这个文件所在的目录的__pycache__下生成一个编译好的文件
为了之后导入这个文件的时候直接读这个编译好的pyc文件就可以
可以节省一些导入时候的时间
importlib.reload(aaa) # 表示重新加载
reload这种方式可以强制程序再重新导入这个模块一次
非常不推荐你使用
在模块的导入中 不要产生循环引用问题
如果发生循环导入了
就会发现明明写在这个模块中的方法,确偏显示找不到
标签:实现 pycharm 应该 importlib 反射 ext 添加 找不到 循环
原文地址:https://www.cnblogs.com/zycorn/p/9415073.html