一文明白Python 的import如何工作
csdh11 2025-04-01 16:56 8 浏览
Python import系统的基础知识
Python 的import系统是该语言设计的关键部分,允许模块化编程和代码的轻松重用。了解这个系统对任何 Python 程序员都很重要,因为它决定了代码的结构、共享和执行方式。
什么是模块?
在 Python 中,模块只是一个包含 Python 定义和语句的文件。文件名是添加了后缀 .py 的模块名称。在模块中,可以定义函数、类和变量,还可以包含可运行的代码。下面是一个名为 mymodule.py :
# mymodule.py
def greet(name):
return f"Hello, {name}!"
class Greeter:
def __init__(self, name):
self.name = name
def greet(self):
return f"Hello, {self.name}!"
# Module-level variable
message = "Welcome to my module"
此模块可以导入并在另一个 Python 脚本中使用:
# main.py
import mymodule
print(mymodule.greet("Kaitlyn"))
greeter = mymodule.Greeter("Alex")
print(greeter.greet())
print(mymodule.message)
包
包是一种使用“带点的模块名称”来构建 Python 模块命名空间的方法。包是包含名为 __init__.py 的特殊文件的目录。 __init__.py 文件(可以是空的或包含初始化代码)的存在向 Python 发出信号,表明该目录应被视为一个包。
下面是包结构的示例:
mypackage/
__init__.py
module1.py
module2.py
可以按如下方式从此包导入模块:
from mypackage import module1
from mypackage.module2 import some_function
Import 语句
Python 提供了多种导入模块和包的方法。最常见的 import 语句是:
- import module_name:这将导入整个模块,需要在其成员前面加上模块名称。
import mymodule
print(mymodule.greet("Kaitlyn"))
- from module_name import member_name:这会将模块中的特定成员直接导入到命名空间中。
from mymodule import greet
print(greet("Kaitlyn"))
- 导入module_name作为别名:这将导入具有别名的模块,允许您使用较短的名称。
import mymodule as mm
print(mm.greet("Kaitlyn"))
- from module_name import *:这会将模块中的所有公共成员导入到命名空间中。通常不鼓励这种做法,因为它可能导致命名空间混乱和潜在的名称冲突。
from mymodule import *
print(greet("Kaitlyn"))
Python 如何执行导入
导入模块时,Python 将执行以下步骤:
- 检查模块是否已导入:如果模块已导入, sys.modules Python 使用缓存版本。
- 查找模块:Python 在 中 sys.path 列出的目录中搜索该模块。
- 编译模块:如果模块是源文件,Python 会将其编译为字节码。
- 执行模块:Python 执行模块的代码以创建模块的命名空间。
从不同位置导入
Python 的灵活性允许您从不同位置导入模块。除了从标准库和已安装的软件包导入外,还可以从自定义目录导入。这通常是通过修改 sys.path 或设置 PYTHONPATH 环境变量来完成的。
相对进口
在具有多个模块的大型项目中,相对导入对于保持模块化和可读性很有用。相对导入使用点表示法来引用当前包和父包。
例如,请考虑以下包结构:
mypackage/
__init__.py
module1.py
subpackage/
__init__.py
module2.py
可以执行相对导入 module2.py 以导入 module1 :
# module2.py
from .. import module1
在此示例中, .. 在包层次结构中向上一层到父包 ( mypackage ),然后 module1 从中导入。
搜索路径以及 Python 查找模块的方式
在 Python 中导入模块时,解释器会遵循系统方法来查找和加载模块。此过程涉及搜索搜索路径中定义的一系列目录。了解此搜索路径对于解决导入错误和有效管理代码库非常重要。
搜索路径
搜索路径由 sys.path 列表定义,该列表包含 Python 搜索模块的目录。目录的 sys.path 顺序决定了搜索顺序。搜索路径的典型组件包括:
- 包含输入脚本的目录:如果正在运行脚本,Python 首先会检查脚本所在的目录。这允许您在不修改搜索路径的情况下导入本地模块。
- PYTHONPATH 环境变量:这是一个环境变量,您可以设置它以将其他目录添加到搜索路径。它是用冒号(在 Unix 上)或分号(在 Windows 上)分隔的目录路径列表。
- 标准库目录:Python 的标准库目录包含内置模块和包。默认情况下,这些目录包含在当前脚本的目录和 PYTHONPATH 之后。
- 第三方站点包:此目录包含通过包管理器安装的包,例如 pip 。它通常位于 Python 安装目录中,包括从 Python 包索引 (PyPI) 安装的模块和包。
查看和修改搜索路径
要查看 Python 环境中的当前搜索路径,可以打印列表 sys.path :
import sys
print(sys.path)
这将输出 Python 将搜索模块的目录列表。
示例:将目录添加到搜索路径
可以在运行时修改 sys.path 列表以包含其他目录。如果您将自定义模块存储在非标准位置,这可能很有用:
import sys
sys.path.append('/path/to/your/modules')
import your_custom_module
sys.path 以这种方式添加目录是临时的,仅影响当前脚本。如果需要永久添加目录,请考虑设置 PYTHONPATH 环境变量或修改 sitecustomize or usercustomize 模块。
模块解析过程
当您尝试导入模块时,Python 会遵循特定的步骤序列来查找和加载该模块:
- 检查模块是否已导入:Python 首先检查 sys.modules 字典以查看模块是否已导入。如果存在,Python 将使用缓存 sys.modules 的版本,并且不会重新加载模块。
- 搜索内置模块:Python 检查模块是否为内置模块(例如, sys 、 os )。内置模块是预先编译的,并包含在 Python 解释器中。
- 搜索 中的 sys.path 目录: Python 按顺序遍历列出的每个 sys.path 目录。它查找与模块名称匹配的文件 .py ,该文件具有 、 .pyc 、 .pyo 、 .pyw 或 .pyd 扩展名(在 Windows 上)或相应的包目录。
示例:了解搜索路径顺序
请考虑以下示例,其中具有以下目录结构:
/project
/scripts
main.py
/modules
mymodule.py
如果 main.py 包含:
import sys
sys.path.append('../modules')
import mymodule
Python 将首先检查 main.py ( /project/scripts 的目录),然后是 (如果设置了)中的 PYTHONPATH 目录,然后是标准库目录,最后是附加到 sys.path 的 ../modules 目录。
处理导入错误
导入错误可能由于各种原因而发生,例如缺少模块、不正确的模块名称或模块代码中的问题。Python 在找不到模块或模块内出现错误时引发 。 ImportError
示例:处理导入错误
处理 ImportError 允许您提供回退机制或信息性错误消息:
try:
import non_existent_module
except ImportError as e:
print(f"Error importing module: {e}")
print("Please make sure the module is installed and the name is correct.")
print("You can try installing it using pip: pip install non_existent_module")
# Optionally, provide fallback code here if the module is not essential.
自定义搜索路径
除了 sys.path 在脚本中进行修改外,还可以通过设置 PYTHONPATH 环境变量或使用 .pth site-packages 目录中的文件来自定义搜索路径。
示例:设置 PYTHONPATH 环境变量
要将目录永久添加到搜索路径,您可以设置 PYTHONPATH 环境变量。例如,在 Unix 系统上,您可以将以下行添加到 或 .bashrc .profile :
export PYTHONPATH="/path/to/your/modules:$PYTHONPATH"
在 Windows 上,可以通过“系统属性”或使用命令提示符中 set 的命令来设置 PYTHONPATH 环境变量:
set PYTHONPATH=C:\path\to\your\modules;%PYTHONPATH%
模块缓存和重新导入模块
当 Python 导入模块时,它会执行多个操作以确保该模块可供使用。此过程的一个关键方面是模块缓存。了解 Python 如何缓存模块以及如何重新导入模块可以帮助您更有效地管理代码,尤其是在开发和调试期间。
模块缓存
导入模块时,Python 会将其存储在名为 sys.modules .此字典跟踪所有导入的模块,将模块名称映射到模块对象。此缓存机制可确保每个模块在每个会话中仅加载一次,从而通过避免冗余加载和初始化来提高性能。
示例:查看缓存的模块
可以通过检查 sys.modules 字典来查看缓存的模块:
import sys
# List all cached modules
print(sys.modules.keys())
# Check if a specific module is cached
if 'mymodule' in sys.modules:
print('mymodule is already imported and cached.')
else:
print('mymodule is not imported yet.')
模块缓存的工作原理
导入模块时,Python 将执行以下步骤:
- 检查 sys.modules :Python 首先检查该模块是否已存在于字典中 sys.modules 。
- 使用缓存模块:如果在 sys.modules 中找到该模块,Python 使用缓存版本。
- 加载和缓存模块:如果找不到该模块,Python 会从文件系统加载该模块,执行其代码,并将其添加到 sys.modules .
此过程可确保同一模块的任何后续导入语句都使用缓存版本,从而避免重复执行模块的代码。
重新导入模块
在开发过程中,您可能需要重新导入模块以反映模块代码中的更改,而无需重新启动 Python 解释器。这在交互式会话和长时间运行的应用程序中特别有用。
示例:使用importlib
Python 提供了该 importlib 模块,其中包括一个 reload 用于重新加载以前导入的模块的函数:
import importlib
import mymodule
# Modify the mymodule.py file externally (e.g., add new functions or update code)
# Reload the module to reflect changes
importlib.reload(mymodule)
通过使用 importlib.reload ,Python 重新执行模块的代码并更新 中的 sys.modules 模块对象。这样可以确保在不重新启动解释器的情况下提供最新的更改。
模块重新导入的用例
- 交互式开发:在交互式环境(如 Jupyter Notebooks 或 IPython shell)中工作时,可用于 importlib.reload 测试模块中的更改,而无需重新启动会话。
- 动态应用程序:在需要动态加载模块的应用程序(如插件或扩展)中,您可以重新加载模块以在运行时更新其功能。
- 调试:调试时,可能需要频繁更改模块的代码。重新加载模块可帮助您立即测试这些更改。
示例:在交互式会话中重新导入模块
下面是在交互式会话期间重新导入模块的分步示例:
- 创建和导入模块
# mymodule.py
def greet(name):
return f"Hello, {name}!"
# Interactive session
import mymodule
print(mymodule.greet("Kaitlyn")) # Output: Hello, Kaitlyn
- 修改模块
更新 mymodule.py 以更改 greet 功能:
# mymodule.py
def greet(name):
return f"Hi, {name}!"
- 重新加载模块
import importlib
importlib.reload(mymodule)
print(mymodule.greet("Kaitlyn")) # Output: Hi, Kaitlyn!
相关推荐
- 用Python轻松修改Word文件的作者和时间,打造自己的专属效率工具
-
你是否曾经遇到过需要批量修改Word文件的作者、创建时间或修改时间的情况?手动操作不仅费时费力,还容易出错。可以用Python编写一个小工具,轻松解决这个问题!无论你是编程新手还是有一定经验的...
- 插件开发js代码划分(js插件编写)
-
在开发Chrome插件时,将JavaScript代码拆分成多个模块而非集中放置,主要基于性能优化、可维护性提升和浏览器插件特性适配等多方面的考量。以下是具体原因及区别分析:一、拆分的核心原因...
- 5分钟掌握Python中的标准输入、标准输出、标准错误
-
读取用户输入从标准输入获取输入:user_input=input("Impartyourwisdom:")print(f"Youshared:{user_input}")...
- 高大上的解答:在 'packages.pyi' 中找不到引用 'urllib3'
-
DeepSeek的一句代码:...
- Flask 入门教程(flask快速入门)
-
目录什么是Flask?环境配置与安装第一个Flask应用:HelloWorld路由与视图函数模板与Jinja2表单处理与用户输入...
- 每日一库之 Go 语言开发者的神器—Gotx
-
点击上方蓝色“Go语言中文网”关注我们,领全套Go资料,每天学习Go语言简介Gotx是一个Go语言(Golang)的解释器和运行环境,只有单个可执行文件,绿色、跨平台,无需安装任何Go语言环境就可...
- MySQL性能调优工具包制作(mysql性能调整)
-
一、最终工具包内容mysql_tuning_toolkit/├──scripts/#核心脚本│├──sysbench-pro.sh#...
- 掌握TensorFlow核心用法:从安装到实战的完整指南
-
一、为什么TensorFlow值得学习?作为全球使用最广泛的开源机器学习框架,TensorFlow已累计获得超过17万GitHub星标,支撑着Google搜索、Waymo自动驾驶、NASA卫星图像分析...
- 如何把PY 打包成EXE安装文件(pypy 打包exe)
-
将Python脚本打包成EXE文件通常使用第三方工具实现,以下是详细步骤和注意事项:...
- Pygame Zero 详细使用教程(python zerorpc)
-
PygameZero是一个基于Pygame的简化游戏开发框架,特别适合初学者和快速原型开发。它隐藏了许多底层的复杂性,使得开发者可以更专注于游戏逻辑的实现。本文将通过分析提供的代码,详细介绍如...
- Stable diffusion AI画图辅助脚本 Script 的使用(二)
-
本篇为脚本使用介绍的第二部分,主要介绍Promptmatrix提示词矩阵以及UltimateSDUpscale终极SD放大这两个脚本,同时也简单介绍一下如何编写自己的脚本。1、Promp...
- 一文明白Python 的import如何工作
-
Pythonimport系统的基础知识Python的import系统是该语言设计的关键部分,允许模块化编程和代码的轻松重用。了解这个系统对任何Python程序员都很重要,因为它决定了代码的结构...
- Highlight.js - 前端的代码语法高亮库
-
千辛万苦写了篇技术分享,贴了一堆代码,兴高采烈地发到了自己的博客网站上。结果却发现代码全是白底黑字,字体还难看得很,你瞬间就没了兴致。能不能让网页也能像IDE那样,做带语法高亮的炫酷显示呢?来看一...
- xbox xsx/s ps2模拟器 战神12,北欧女神2 配置教程
-
xsxxss下载PS2独立模拟器,Retroarch全能模拟器地址。...
- RetroArch 着色器、金手指怎么用? 重返复古游戏萤幕滤镜效果
-
自从上次分享RetroArch模拟器的一些技巧后,许多模拟器新用户对老旧游戏机感到好奇,为什么游戏画面看起来会有很多马赛克。这主要是因为当年的游戏开发商是针对当时的屏幕进行设计的,所以在现在的高分辨率...
- 一周热门
- 最近发表
-
- 用Python轻松修改Word文件的作者和时间,打造自己的专属效率工具
- 插件开发js代码划分(js插件编写)
- 5分钟掌握Python中的标准输入、标准输出、标准错误
- 高大上的解答:在 'packages.pyi' 中找不到引用 'urllib3'
- Flask 入门教程(flask快速入门)
- 每日一库之 Go 语言开发者的神器—Gotx
- MySQL性能调优工具包制作(mysql性能调整)
- 掌握TensorFlow核心用法:从安装到实战的完整指南
- 如何把PY 打包成EXE安装文件(pypy 打包exe)
- Pygame Zero 详细使用教程(python zerorpc)
- 标签列表
-
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- parsevideo (33)
- 个人网站源码 (37)
- centos7.4下载 (33)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- jdk1.8.0_191下载 (33)
- axure9注册码 (33)
- pts/1 (33)
- spire.pdf 破解版 (35)
- shiro jwt (35)
- sklearn中文手册pdf (35)
- itextsharp使用手册 (33)
- 凯立德2012夏季版懒人包 (34)
- 反恐24小时电话铃声 (33)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)