0

0

Python 项目结构如何设计更合理

冷漠man

冷漠man

发布时间:2026-02-28 18:57:21

|

661人浏览过

|

来源于php中文网

原创

python项目结构合理的关键是按需分层、职责清晰、约定明确,典型结构包括src/(主程序包)、tests/(镜像src的测试)、scripts/(运维脚本)、configs/(多环境配置)、docs/(轻量文档),并采用src布局、绝对导入、pyproject.toml依赖管理、虚拟环境隔离及pre-commit自动化。

python 项目结构如何设计更合理

Python 项目结构合理的关键,是让代码可维护、易测试、好部署,同时兼顾团队协作和未来扩展。不是越复杂越好,而是按需分层、职责清晰、约定明确。

核心目录划分要体现关注点分离

避免把所有文件堆在根目录下。典型且实用的分层结构如下:

  • src/:存放主程序包(如 myapp/),包含业务逻辑、API、核心类。这是可安装的 Python 包,应有 __init__.py 和清晰的模块划分(如 models/services/utils/
  • tests/:与 src/ 平级,用 pytest 组织,目录结构尽量镜像 src/(如 tests/test_models/),方便定位对应测试
  • scripts/bin/:放运维脚本、数据初始化、临时工具等非业务逻辑的可执行文件
  • configs/:配置文件(dev.yamlprod.env 等),不硬编码,支持环境变量覆盖
  • docs/:轻量级说明(架构图、快速上手)、不是必须但强烈建议有 README.md(含安装、运行、测试命令)

包命名和导入路径要一致且可预测

推荐使用 src/ 源码布局,并在 pyproject.toml 中声明:

[project]
# …
[project.optional-dependencies]
dev = ["pytest", "black", "mypy"]

安装时用 pip install -e ".[dev]",确保本地开发时 import myapp 能直接解析到 src/myapp/。避免在代码里写 sys.path.insert(0, ...) 或相对导入混乱。

名品购物网店系统
名品购物网店系统

适合品牌专卖店专用,从前台的美工设计就开始强调视觉形象,有助于提升商品的档次,打造网店品牌!后台及程序核心比较简洁,着重在线购物,去掉了繁琐的代码及垃圾程式,在结构上更适合一些中高档的时尚品牌商品展示. 率先引入语言包机制,可在1小时内制作出任何语言版本,程序所有应用文字皆引自LANG目录下的语言包文件,独特的套图更换功能,三级物品分类,购物车帖心设计,在国内率先将购物车与商品显示页面完美结合,完

下载

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

跨模块引用统一用绝对导入:
from myapp.models.user import User
from ..models.user import User(难维护、IDE 不友好)

配置、环境与依赖要解耦且可复现

区分三类依赖和配置:

  • 依赖管理:用 pyproject.toml(现代标准),而非 requirements.txt 主文件;生成锁定文件用 pip-compilepoetry lock
  • 环境隔离:每个项目配独立虚拟环境(python -m venv .venv),不共用全局解释器
  • 配置加载:用 pydantic-settingsdynaconf,支持多环境、类型校验、优先级(环境变量 > YAML > 默认值)

测试与自动化要从第一天就嵌入结构

结构本身要为测试服务:

  • 把 fixture、mock 数据放在 tests/conftest.pytests/data/ 下,不散落在各测试文件中
  • 单元测试聚焦函数/类行为,用 unittest.mockpytest-mock 隔离外部依赖(DB、HTTP)
  • 集成测试单独建 tests/integration/,启动真实 DB 或轻量服务(如 pytest-asyncio + testcontainers
  • CI 脚本(GitHub Actions / GitLab CI)直接调用 pytest tests/ --cov=myapp,覆盖率报告不绕路

不复杂但容易忽略:结构定下来后,用 pre-commit 固化代码风格(black + isort + ruff),让新成员拉下代码就能跑通,而不是先花半天配环境。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
pip安装使用方法
pip安装使用方法

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

371

2023.10.09

更新pip版本
更新pip版本

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

429

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、保存并关闭文件即可。

792

2024.12.23

python升级pip
python升级pip

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

367

2025.07.23

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

429

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

599

2023.08.10

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

3061

2026.01.21

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

482

2023.11.09

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

6

2026.02.28

热门下载

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

精品课程

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

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.7万人学习

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

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