随笔- 310  文章- 1  评论- 0  阅读- 86009 

import语句导入指定的模块时会执行3个步骤

  • 找到模块文件,在指定的路径下搜索模块文件
  • 编译成字节码,文件导入时就会编译,因此,顶层文件的.pyc字节码文件在内部使用后会被丢弃,只有被导入的文件才会留下.pyc文件
  • 执行模块的代码来创建其所定义的对象,模块文件中的所有语句会依次执行,从头至尾,而此步骤中任何对变量名的赋值运算,都会产生所得到的模块文件 的属性

注:

  • 再次导入操作只不过是提取内存中已加载的模块对象
  • reload()可用于重新加载模块

Python解释器在import 模块时必须先找到对应得模块文件

  • 程序的主目录
  • PYTHONPATH目录(如果设置了此变量)
  • 标准链接库目录
  • 任何.pth文件的内容(如果存在.pth文件)

这四个组合起来即为sys.path所包含的路径,而Python会选择在搜索路径中的第一个符合导入文件名的文件

 

 posted on   boye169  阅读(127)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
点击右上角即可分享
微信分享提示