0

0

Python模块与包管理教程_import机制与项目组织

冷炫風刃

冷炫風刃

发布时间:2026-01-11 17:36:09

|

863人浏览过

|

来源于php中文网

原创

python import 是动态加载模块、构建命名空间、处理依赖的过程;模块是.py文件,包是含__init__.py的目录;需合理组织项目结构(如src布局)、避免循环导入、用python -m运行确保路径正确。

python模块与包管理教程_import机制与项目组织

Python 的 import 机制不是简单的“把代码复制进来”,而是动态加载模块对象、构建命名空间、处理依赖关系的过程。理解它,才能合理组织项目、避免循环导入、正确发布包、调试导入错误。

模块(.py 文件)是 import 的基本单位

每个 .py 文件默认就是一个模块,文件名(不含 .py)即模块名。import 时 Python 会按 sys.path 列表顺序查找该名字对应的文件:

  • 先查内置模块(如 sys、json),命中则直接加载
  • 再依次检查 sys.path 中的目录:脚本所在目录、PYTHONPATH 路径、标准库路径、site-packages 等
  • 找到 xxx.py 就编译为字节码(.pyc),执行其顶层代码,生成 module 对象并缓存到 sys.modules

注意:重复 import 同一模块不会重新执行,而是直接返回缓存对象——这是实现单例和避免重复初始化的关键。

包(含 __init__.py 的目录)支持层级导入

一个普通目录只要包含空文件 __init__.py(Python 3.3+ 可省略,但显式保留更清晰),就成为包。包允许用点号分隔的层级结构,比如 from mypackage.submodule import func

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

启山智软物流配送系统
启山智软物流配送系统

启山智软物流配送是基于Spring Cloud 和 Vue.js的JAVA物流配送系统。包含总控制后台 、城市合伙人(商家pc端)、 区域团长后台 、用户端小程序 、手机H5等多个操作模块。为响应用户需求我们新增了后台自定义装修组件模块,使页面更加美观,操作更加灵活简便。淘宝商品CSV一键导入,提升用户使用感。还有与众不同的管理台侧边栏设计,打破传统管理台样式。 另有公众号接龙、引导页上传、区域团

下载
  • __init__.py 可为空,也可定义 __all__ 控制 from package import * 导入的内容
  • 包内模块可通过相对导入(from . import modulefrom ..utils import helper),但仅限在包内模块中使用,且必须以模块方式运行(不能直接 python submodule.py)
  • 绝对导入更推荐:from mypackage.utils import log,清晰、可预测、易重构

项目结构要兼顾可运行性与可安装性

常见错误是把脚本和模块混放,导致导入失败或无法 pip install。推荐结构:

myproject/
├── pyproject.toml          # 定义构建系统、依赖、元数据(现代标准)
├── src/
│   └── mypackage/           # 实际代码放 src 下,避免本地开发时意外 import 当前目录
│       ├── __init__.py
│       ├── core.py
│       └── utils/
│           ├── __init__.py
│           └── helpers.py
├── tests/
│   └── test_core.py
└── scripts/
    └── run_app.py           # 入口脚本,通过 -m 方式调用:python -m mypackage.core

关键点:

  • src 目录隔离源码,配合 pyproject.toml 中的 packages = [{include = "mypackage", from = "src"}],确保 pip install 正确打包
  • 入口脚本不直接 import 同级模块,而是用 python -m mypackage.main,让 Python 把 src 加入 sys.path
  • 测试文件应能独立发现和运行,pytest 默认支持从项目根运行,自动识别 src 下的包

常见导入问题与排查方法

遇到 ImportError 或 ModuleNotFoundError,别急着改 sys.path:

  • 运行 python -v -c "import mypackage" 查看详细导入路径和失败点
  • 检查当前工作目录是否影响了 sys.path(尤其 IDE 中默认工作目录可能不是项目根)
  • 确认 __init__.py 存在且未报语法错误(它被导入时也会执行)
  • 循环导入典型表现:A.py 导入 B,B.py 导入 A,且都在顶层执行语句。解法是延迟导入(函数内 import)或重构依赖
  • 虚拟环境未激活或 pip install -e . 没运行,会导致本地修改不生效

掌握 import 的实际行为,比死记语法更重要。它决定了你的代码能否被他人复用、能否在不同环境中稳定运行。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

452

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

329

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

373

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

431

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

793

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

370

2025.07.23

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

4

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号