python import的本质探究

import不仅加载代码,还通过sys.modules缓存模块,确保唯一性;它按sys.path搜索路径查找模块,执行顶层代码并创建命名空间;模块级变量共享,支持相对导入与包结构,需注意循环导入和可变对象副作用。

python import的本质探究

import在Python中不只是加载代码,它背后有一套完整的机制来确保模块的正确加载、缓存和共享。理解import的本质,能帮助我们写出更清晰、可维护的代码。

import做了什么?

当你写import math时,Python并不是简单地把math.py的内容复制过来。它会执行以下步骤:

查找名为math的模块是否已经在sys.modules中(这是所有已加载模块的缓存字典)如果不在,就按路径顺序在sys.path中搜索math.py、math.so或内置模块找到后,创建一个module对象,执行该文件中的顶层代码(比如赋值、函数定义)将这个module对象存入sys.modules,并绑定到当前命名空间

这意味着同一个模块在整个程序中只会被导入一次,后续import都指向同一个对象。

模块的唯一性与共享状态

由于模块会被缓存,多次导入不会重复执行模块代码。这带来一个重要特性:模块级别的变量是全局共享的。

立即学习“Python免费学习笔记(深入)”;

例如:

# config.py
counter = 0

a.py

import config
config.counter += 1

b.py

import config
print(config.counter) # 输出 1,不是 0

这种机制常被用来实现单例模式或共享配置。但也要小心,模块中的可变对象(如列表、字典)可能被不同地方修改,造成意外副作用。

import的搜索路径机制

Python通过sys.path决定从哪里找模块。它是一个字符串列表,包含:

脚本所在目录PYTHONPATH环境变量指定的路径安装目录下的标准库路径.pth文件定义的额外路径

你可以动态修改sys.path来扩展搜索范围,但更推荐使用虚拟环境或打包工具(如setuptools)管理依赖。

相对导入与包结构

当项目结构复杂时,包(package)通过__init__.py组织模块。相对导入允许模块引用同包内的其他模块。

例如:

# mypkg/utils.py
def helper(): pass

mypkg/app.py

from .utils import helper # 相对导入

注意:相对导入只能在包内使用,不能用于主模块(直接运行的脚本)。

基本上就这些。import看似简单,实则涉及命名空间、缓存、路径查找和执行模型的协同工作。掌握这些细节,才能避免循环导入、路径错误等问题。不复杂但容易忽略。

以上就是python import的本质探究的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1375153.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 14:46:07
下一篇 2025年12月14日 14:46:17

相关推荐

  • python正则表达式如何匹配内容

    Python中使用re模块进行正则匹配,常用函数有re.match()、re.search()、re.findall()和re.finditer();其中re.search()更实用,能扫描整个字符串。元字符如.、d、w、*、+、?、^、$和[]用于构建匹配模式,例如d{3}-d{4}可匹配&#82…

    2025年12月14日
    000
  • python 如何安装py4j

    安装 py4j 最简单的方式是使用 pip。1. 在终端运行 pip install py4j 即可安装,之后通过 from py4j.java_gateway import JavaGateway 验证导入是否成功。2. 若无法使用 pip,可手动下载源码包并执行 python setup.py …

    2025年12月14日
    000
  • Pandas插值精度丢失问题:如何正确处理缺失值插值

    本文旨在解决Pandas数据处理中,使用interpolate函数进行缺失值插值时可能出现的精度丢失问题。通过分析问题根源,提供正确的解决方案,确保插值结果的准确性和可靠性,避免数据类型错误导致的精度损失。 在使用 Pandas 进行数据分析时,经常会遇到缺失值(NaN)。interpolate 函…

    2025年12月14日
    000
  • 使用Python字典通过值查找并返回其他值

    本文介绍了如何使用Python字典,通过给定的值反向查找并返回与该值相关联的其他值。通过遍历字典的键值对,并判断目标值是否存在于字典的值集合中,从而实现反向查找的功能。同时,也讨论了当字典的值为集合时,结果顺序不确定的问题,并提供了使用列表替代集合以保持结果顺序的方法。 在化学应用中,经常需要根据元…

    2025年12月14日
    000
  • 基于元素信息反查的Python字典应用教程

    本文旨在提供一个Python字典应用示例,解决根据元素的部分信息(如符号、原子序数、原子量)反查元素其他信息的常见需求。文章将详细介绍如何构建包含元素信息的字典,并提供通过值查找键以及返回相关信息的实现方法,并针对集合的无序性问题提出解决方案。 在化学相关应用中,经常需要根据元素的各种属性(例如元素…

    2025年12月14日
    000
  • python __dict__的使用注意

    dict 是 Python 中用于查看对象属性字典的内置属性,返回包含实例或类自定义属性的字典。1. 它仅包含动态添加的实例属性,不包括类方法、继承属性或使用 slots 的属性;例如 Person 类中 species 为类属性,不在实例 dict 中。2. 类与实例的 dict 独立存在,修改实…

    2025年12月14日
    000
  • Pandas插值精度丢失问题及解决方案

    本文旨在解决在使用 Pandas 的 interpolate() 方法进行数据插值时,可能出现的精度丢失问题。通过分析问题原因,并提供使用 MultiIndex 正确读取数据的方法,确保插值结果的精度符合预期,避免将浮点数插值为整数。 在使用 Pandas 进行数据分析时,interpolate()…

    2025年12月14日
    000
  • python中socket如何建立服务器

    答案:Python中使用socket创建服务器需依次创建套接字、绑定地址端口、监听、接受连接并通信。首先通过socket.socket(socket.AF_INET, socket.SOCK_STREAM)创建TCP套接字,再调用bind()绑定’localhost’或&#8…

    2025年12月14日
    000
  • Python AES 加密解密后文本为空问题的解决方案

    本文旨在解决在使用 Python 的 Crypto 库进行 AES 加密解密时,解密后得到空字符串的问题。通过分析代码,找出问题根源在于密钥处理方式不正确,并提供修正后的代码示例,确保加密和解密过程的正确性,最终实现数据的可靠保护。 在使用 Python 的 Crypto 库进行 AES 加密和解密…

    2025年12月14日
    000
  • Python教程:高效生成无对角线元素的稀疏矩阵COO格式

    本教程旨在指导用户如何高效生成用于构建稀疏邻接矩阵的行(row)和列(col)索引列表,确保矩阵中不包含对角线元素(即row[i] != col[i])。我们将利用NumPy的强大功能来生成所有非对角线索引对,并结合SciPy库将其转换为COO(Coordinate Format)稀疏矩阵,同时提供…

    2025年12月14日
    000
  • Python/Numpy:高效生成非对角线稀疏矩阵索引与COO格式构建

    本教程详细介绍了如何使用Python和Numpy高效生成用于稀疏矩阵(特别是COO格式)的非对角线索引对。文章提供了两种主要方法:一种是利用Numpy的广播和条件筛选功能,自动生成所有非对角线索引;另一种是基于已有的行、列和值数据,构建或可视化密集矩阵。通过这些技术,用户可以避免手动创建重复的对角线…

    2025年12月14日
    000
  • 解决Python文件读取验证中的换行符问题及高效文件管理

    本文深入探讨Python文件读取验证失败的常见原因,特别是f.read()方法可能引入的隐藏换行符。教程提供使用strip()方法去除多余字符的解决方案,并强调利用with语句进行安全高效文件操作的最佳实践,同时介绍基础调试技巧,帮助开发者编写更健壮的文件处理代码。 理解文件读取的隐秘行为 在pyt…

    2025年12月14日
    000
  • 使用BeautifulSoup从HTML页面中提取并构建特定标签的教程

    本文详细介绍了如何利用Python的BeautifulSoup库,高效且优雅地从现有HTML文档中选择性地提取特定标签及其内容,并将其重新构建成一个新的HTML页面。通过避免手动字符串拼接,采用BeautifulSoup内置的DOM操作方法,实现代码的清晰性、可维护性与健壮性,是处理HTML内容过滤…

    2025年12月14日 好文分享
    000
  • python协程调度的流程

    Python协程依赖事件循环实现协作式调度,通过async/await语法定义和控制协程的挂起与恢复;调用async函数返回协程对象,需封装为任务(Task)并注册到事件循环;事件循环维护就绪与等待队列,当协程遇到await时主动让出CPU,执行权交还事件循环,后者从就绪队列中选取下一个任务执行;I…

    2025年12月14日
    000
  • python中Roberts算子是什么

    Roberts算子通过2×2卷积核检测45°和135°方向边缘,使用Gx=[[1,0],[0,-1]]和Gy=[[0,1],[-1,0]]计算梯度幅值,Python中可用OpenCV实现,具有计算快但对噪声敏感的特点,适用于边缘清晰、噪声少的图像,是理解边缘检测基础的重要方法。 Roberts算子是…

    2025年12月14日
    000
  • Django多项目共享模型:通用数据库配置与管理策略

    本教程探讨了在多个Django项目之间高效共享特定模型数据(如Word模型)的策略。通过在settings.py中配置多个数据库,并结合.using()方法或自定义模型管理器,可以使不同项目访问同一个通用数据库,从而避免重复数据传输和管理,实现数据的集中化存储和访问。 引言 在企业级应用开发中,我们…

    2025年12月14日
    000
  • Python文件读取与字符串比较:避免隐藏的换行符陷阱

    本文探讨了Python文件读取中常见的陷阱,即f.read()可能引入的换行符导致字符串比较失败。教程详细介绍了如何使用strip()方法清除多余空白字符,确保准确的字符串匹配。同时,强调了使用with语句进行文件操作的最佳实践,以确保资源正确释放。最后,提供了实用的调试技巧,帮助开发者快速定位并解…

    2025年12月14日
    000
  • 使用Python多进程优化大数据量匹配与筛选性能

    本文旨在解决Python处理大数据量列表匹配与筛选时遇到的性能瓶颈,特别是当传统多线程方案效果不佳时。我们将深入探讨如何利用Python的multiprocessing模块,结合Manager实现进程间数据共享,以及合理的任务分块策略,显著提升CPU密集型任务的执行效率,从而将耗时数十分钟的操作缩短…

    2025年12月14日
    000
  • 在 GitHub 中展示 Python 项目代码覆盖率

    本文将介绍如何配置 GitHub Actions,以便在每次推送代码时自动生成并展示 Python 项目的代码覆盖率报告。我们将使用 pytest-cov 工具来生成覆盖率数据,并通过简单的配置修改,使其在 GitHub 上可见。 使用 pytest-cov 生成代码覆盖率报告 要在 GitHub …

    2025年12月14日
    000
  • Python字符串中数字与文字数字的鲁棒提取教程

    本教程旨在解决从包含混合数字(阿拉伯数字和英文拼写数字)的字符串中提取首尾数字的挑战。文章将深入探讨传统字符串替换方法的局限性,并提供两种主要解决方案:利用Python正则表达式实现精确且能处理重叠匹配的策略,以及介绍 word2number 库在完整数字短语转换中的应用,同时明确其在复杂字符串解析…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信