python:软件目录结构规范

为什么要设计好目录结构?

“设计项目目录结构”,就和“代码编码风格”一样,属于个人风格问题。对于这种风格上的规范,一直都存在两种态度:

  1.一种认为,这种个人风格问题“无关紧要”。理由是能让程序work就好,风格问题根本不是问题。

  2.另一种认为,规范化能更好地控制程序结构,让程序具有更高的可读性。

个人倾向于后者。“项目目录结构”其实也是属于“可读性和可维护性”的范畴,我们设计一个层次清晰的目录结构,就是为了达到以下两点:

  1.可读性高:不熟悉这个项目的代码的人,一眼就能看懂目录结构,知道程序启动脚本是哪个,测试目录在哪儿,配置文件在哪儿等等。从而非常快速的了解这个项目。

  2.可维护性高:定义好组织规则后,维护者就能很明确地知道,新增的哪个文件和代码应该放在什么目录之下。这个好处是,随着时间的推移,代码/配置的规模增加,项目结构不会混乱,仍然能够组织良好

故而,保持一个层次清晰的目录结构是有必要的。更何况组织一个良好的工程目录,其实是一件很简单的事儿。

 

目录组织方式:

关于如何组织好一个较好的python工程目录结构,已经有一些得到了共识额目录结构。在Stackoverflow这个问题上,能看到大家对python目录结构的讨论.

如:假设你的项目名为foo,个人建议的最方便快捷目录结构这样就足够了

Foo/
|-- bin/
| |-- foo
|
|-- foo/
| |-- tests/
| | |-- __init__.py
| | |-- test_main.py
| |
| |-- __init__.py
| |-- main.py
|
| |-- conf.py
| |-- abc.rst
|
|-- setup.py
|-- requirements.txt
|-- README
简单解释一下:
1.bin/:存放项目的一些可执行文件,当然你可以起名script/之类的也行。
2.foo/:存放项目的所有源代码。(1)源代码中的的所有模块、包都应该放在此目录。不要置于顶层目录。(2)其子目录tests/存放单元测试代码;
(3)程序的入口最好命名为main.py
3.docs/:存放一些文档。
4.setup.py:安装、部署、打包的脚本。
5.requirements.txt:存放软件依赖的外部python包列表。
6.README:项目说明文件
除此之外,有一些方案给出了更加多的内容。比如LIENSE.txt,ChangeLog.txt文件等(这里没有列出,是因为这些东西在项目开源时才用得到)

关于README的内容
这个文件,个人觉得是每个项目都该有的一个文件,目的是能简要描述项目的信息,让读者快速了解这个项目。
它主要说明以下几个事项:
1.软件定位,软件的基本功能。
2.运行代码的方法:安装环境、启动命令等。
3.简要的使用说明。
4.代码目录结构说明,更详细点可以说明软件的基本原理。
5.常见问题说明。

 

转载于:https://www.cnblogs.com/cansun/p/8120281.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/281541.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开启智能生活新时代 河北省智慧社区建设从各个击破

智慧社区作为智慧城市的重要组成部分,是城市智慧落地的触点,是城市管理、政务服务和市场服务的载体。随着智慧城市的推广以及新一代技术的普及,智慧社区的项目必将迎来新一轮的快速发展。2016年智慧社区成为企业业务落地的承载点,…

C# WPF 表格控件的前后台数据交互?

概述GridControl控件使用我们已经进行了实例讲解,这节内容我们列举一个特殊的应用场景:表格中有一列CheckBox,默认都处于勾选状态,当用户通过界面操作后,我们要确保用户至少选择了一项,相当于一次数据验证&…

Java(C#)基础差异-语法

1、long类型 Java long类型,若赋值大于int型的最大值,或小于int型的最小值,则需要在数字后加L或者l,表示该数值为长整数,如long num2147483650L。 举例如下: public static void main(String[] args) {/** …

android防止左向右滑出程序,Android——ViewPager禁止左右滑动的实现

目录1 背景用ViewPagerBottomNavigationView多个Fragment快速搭建的页面切换架构,一个有四个页面,因为测试需要,需要屏蔽掉中间的两个,做法是:设置不可点击选择:xml布局文件中,BottomNavigation…

Yii2 的快速配置 api 服务 yii2-fast-api

yii2-fast-api yii2-fast-api是一个Yii2框架的扩展,用于配置完善Yii2,以实现api的快速开发。 此扩展默认的场景是APP的后端接口开发,因此偏向于实用主义,并未完全采用restfull的标准,方便前端开发处理接口数据以及各种…

.NET6打包部署到Windows Service

1.安装Nuget包安装以下nuget包支持windows service<PackageReference Include"Microsoft.AspNetCore.Hosting.WindowsServices" Version"6.0.10" /> <PackageReference Include"Microsoft.Extensions.Hosting.WindowsServices" Version…

传统家电在智能家居变革的五大优势

而在众多向智能家居领域转型变革的企业中&#xff0c;看似落后的传统家电企业&#xff0c;却占据着一定的优势。 产品优势 传统家电企业在产品上的优势主要体现在企业拥有产品本身的设计、技术、生产、制造和营销渠道&#xff0c;其产品不论是从外观设计、零件制造还是零件组装…

《Apache Kafka实战》读书笔记-调优Kafka集群

《Apache Kafka实战》读书笔记-调优Kafka集群 作者&#xff1a;尹正杰 版权声明&#xff1a;原创作品&#xff0c;谢绝转载&#xff01;否则将追究法律责任。 一.确定调优目标 1>.常见的非功能性要求 一.性能&#xff08;performance&#xff09;最重要的非功能性需求之一。…

android emoji unicode编码表,unicode编码

unicode编码app是一款字符查找客户端应用&#xff0c;通过unicode编码可以方便寻找特定字符&#xff0c;查看字符表情详细的描述&#xff0c;并且利用unicode编码就可以快捷复制任意unicode编码&#xff0c;提高开发效率&#xff0c;非常的实用&#xff0c;快来下载unicode编码…

物联网商机诱人 芯片商大力搭建生态系统

应用需求变化多端的物联网&#xff0c;虽具备庞大的发展潜力及应用商机&#xff0c;但由于市场过于分散&#xff0c;几乎没有杀手应用可言&#xff0c;因此对有意耕耘相关市场的半导体业者而言&#xff0c;如何借力使力&#xff0c;寻找盟友共同搭建出的生态系统&#xff0c;遂…

ASP.NET Core 6框架揭秘实例演示[30]:利用路由开发REST API

借助路由系统提供的请求URL模式与对应终结点之间的映射关系&#xff0c;我们可以将具有相同URL模式的请求分发给与之匹配的终结点进行处理。ASP.NET的路由是通过EndpointRoutingMiddleware和EndpointMiddleware这两个中间件协作完成的&#xff0c;它们在ASP.NET平台上具有举足轻…

数据库(二)tab补全功能,使数据库支持简体中文,日志管理,备份脚本

一、如何在MySQL数据库中使用tab键补全功能 1.修改主配置文件/etc/my.cnf vim /etc/my.cnf [mysql] #no-auto-rehash auto-rehash 2.重启MySQL服务&#xff0c;登录测试 /etc/init.d/mysqld restart mysql -uroot -p (可在数据库中使用tab键&#xff09; 3.&#xff1b;临时支持…

php new self()关键字的用法

今天开框架源码&#xff0c;发现有用到new self()的用法 有点不懂 在网上查了一下&#xff0c;给大家说一下&#xff1a; 在类中 self的用法 和this的用法差不多 &#xff0c; php new self() 一般在类内部使用&#xff0c;作用是对自身类实例化&#xff0c;下面给个实例讲解…

android listview item置顶,ListView的item置顶

ListView的item设置置顶1.activitypublic class TopListViewActivity extends Activity {private static int ON_TOP 1;private static int CANCEL_TOP 0;public static String TOP_STATES "TOP";private ListView mListView;private List sessionList;private Se…

电信运营商x86服务器定制策略

近几年&#xff0c;伴随云计算、大数据、移动互联网、物联网等新技术从概念到实践&#xff0c;业务、用户数据海量式爆发增长&#xff0c;作为承载这些业务发展的服务器行业也面临巨大的机遇和挑战。一方面&#xff0c;需求的爆发式增长大幅提升了市场空间&#xff0c;尤其是大…

企业数字化转型服务+方案

前言&#xff1a;本文的阅读对象是公司老板、或企业高层管理者&#xff01;1【背景介绍】数字经济与实体经济深度融合是助推我国经济高质量发展的重要环节。为加快数字中国建设&#xff0c;中央和地方政府都出台各类政策扶植数字化转型相关项目。马云在接受采访时也提到&#x…

在 MongoDB 上模拟事务操作来实现支付

我们的产品叫「学海密探」&#xff0c;属于在线教育行业&#xff0c;产品需要有支付功能&#xff0c;然而支付最蛋疼是什么&#xff1f;有人会说是支付宝和微信等支付接口的接入开发&#xff01;没错&#xff0c;但支付接口的开发算是比较简单的了&#xff0c;我觉得凡是跟钱有…

Zabbix server is not running

问题描述 Dashbord中提示Zabbix server is not running 分析过程 首先查看zabbix-server的运行状态 systemctl status zabbix-server 确定是否是active(running)状态&#xff0c;如果不是&#xff0c;重启zabbix-server查看log tail -f /var/log/zabbix/zabbix_server.log 导致…

android 把异常写入到文本里,尝试在Android中将文件写入sdcard时发生FileNotFoundException(权限被拒绝)...

从标题中可以看到&#xff0c;我在Android中将文件写入sdcard时遇到问题.我想写入将在sdcard上的公共空间中的文件&#xff0c;以便任何其他应用程序都可以读取它。首先&#xff0c;我检查sdcard是否已安装&#xff1a;Environment.getExternalStorageState();然后&#xff0c;…

.NET性能优化-使用ValueStringBuilder拼接字符串

前言这一次要和大家分享的一个Tips是在字符串拼接场景使用的&#xff0c;我们经常会遇到有很多短小的字符串需要拼接的场景&#xff0c;在这种场景下及其的不推荐使用String.Concat也就是使用运算符。 目前来说官方最推荐的方案就是使用StringBuilder来构建这些字符串&#xff…