0

0

Python包结构设计教程_大型项目代码组织方式

冰川箭仙

冰川箭仙

发布时间:2026-01-10 15:55:41

|

205人浏览过

|

来源于php中文网

原创

大型Python项目应按业务域分层,如orders/、products/,每域内设domain/application/infrastructure子包;公共能力抽为shared/;接入层(api/cli)仅作输入输出,业务逻辑全在application层;测试与代码同目录;__init__.py显式声明公共API。

python包结构设计教程_大型项目代码组织方式

大型Python项目不是把所有代码塞进一个文件夹就完事,关键在于分层清晰、职责明确、易于测试和扩展。包结构设计本质是定义模块间的依赖边界和演进路径。

核心原则:按领域分层,而非技术类型

别用“models/”、“views/”、“utils/”这种纯技术分类方式堆砌目录——它会让业务逻辑四处散落,改一个功能要跳转七八个地方。应该以业务域(Domain)或核心能力为单位组织顶层包。

  • 例如电商项目,顶层可设 orders/products/payments/,每个包内再按需包含 domain/(实体、值对象、领域服务)、application/(用例、DTO、命令处理)、infrastructure/(数据库适配、第三方API封装)
  • 公共基础能力(如日志、配置、异常体系)单独抽成 shared/common/ 包,禁止业务包直接 import 其他业务包的内部模块
  • 顶层不放 .py 文件,只保留 __init__.py(可为空)和 pyproject.toml 相关配置

入口与隔离:main 和 api 层要轻量且无业务逻辑

CLI 命令、Web 接口、定时任务等都属于“接入层”,只负责解析输入、调用 application 层、格式化输出。它们不能持有领域模型,也不能直连数据库。

  • cli/ 下每个命令对应一个独立模块,如 cli/order_create.py,仅初始化命令参数并转发给 orders.application.create_order()
  • api/(如 FastAPI)中路由函数只做数据校验和 DTO 转换,业务动作全部委托给 application 层函数或类方法
  • 接入层通过依赖注入容器(如 dependencies.py)获取 service 实例,避免硬编码初始化

测试友好性:每个业务包自带 tests/ 子目录

测试代码必须和被测代码物理相邻,而不是全堆在项目根目录的 tests/ 里。这样重构某个域时,能一眼看到影响范围,并快速运行对应测试。

ModelGate
ModelGate

一站式AI模型管理与调用工具

下载

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

  • 每个 orders/ 包下建 tests/,结构镜像源码:tests/domain/test_order.pytests/application/test_create_order.py
  • 单元测试聚焦单个函数或类,用 unittest.mockpytest-mock 替换 infrastructure 依赖(如 mock 数据库 session
  • 集成测试放在项目级 tests/integration/,验证跨包协作,例如“下单 → 扣库存 → 发通知”全流程

可维护细节:__init__.py 的公开接口控制

每个包的 __init__.py 是该包对外的“门面”。它不该是自动导入所有子模块的中转站,而应显式声明哪些符号是供外部使用的稳定 API。

  • orders/__init__.py 可写:# public API
    from .application import create_order, cancel_order
    from .domain import Order, OrderStatus
  • 隐藏实现细节:不导出 infrastructure/ 下的类,不导出 domain/_validation.py 这类私有模块
  • 配合 py.typed 文件 + 类型注解,让 mypy 和 IDE 精准识别包的公共契约

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API

Python FastAPI 异步开发利用 async/await 关键字,通过定义异步视图函数、使用异步数据库库 (如 databases)、异步 HTTP 客户端 (如 httpx),并结合后台任务队列(如 Celery)和异步依赖项,实现高效的 I/O 密集型 API,显著提升吞吐量和响应速度,尤其适用于处理数据库查询、网络请求等耗时操作,无需阻塞主线程。

28

2025.12.22

Python 微服务架构与 FastAPI 框架
Python 微服务架构与 FastAPI 框架

本专题系统讲解 Python 微服务架构设计与 FastAPI 框架应用,涵盖 FastAPI 的快速开发、路由与依赖注入、数据模型验证、API 文档自动生成、OAuth2 与 JWT 身份验证、异步支持、部署与扩展等。通过实际案例,帮助学习者掌握 使用 FastAPI 构建高效、可扩展的微服务应用,提高服务响应速度与系统可维护性。

251

2026.02.06

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

336

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

776

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1954

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

658

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2401

2025.12.29

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

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

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