软件目录结构规范
alex_老男孩:
为什么要设计好目录结构?
“设计项目目录结构”,就和“胆码编码风格”一样,属于个人风格问题。对于这种风格上的规范,一直都存在两种态度:
    1.一类同学认为,这种个人风格问题“无关紧要”理由是能让程序work就好,风格问题根本不是问题。
    2.另一类同学认为,规范化能更好的控制程序结构,让程序具有更高的可读性。
我比较偏向理解后者的,因为我是一种同学思想行为下的直接受害者。我曾静维护过一个非常不好的项目,其实逻辑并不复杂,但是却耗费了我非常长的时间去理解它想要表达的意思。从此个人对提高项目可读性、可维护性的要求就很高了。
“项目目录结构”其实额是属于“可读性和可维护性”的范畴,我们设置一个层次清晰的目录结构,就是为了达到一下两点:
    1.可读性高:不熟悉换个项目的代码人,一眼就能看懂目录结构,知道程序的启动脚本是那个,测试目录在那里,配置文件在哪里等等。从而非常快速的了解这个项目。
    2.可维护性高:定义好组织规范后,维护者就能很明确地知道,新增的那个文件和代码应该在什么目录之下。这个好处是,随着时间的退役,代码/配置的规模增加,项目结构不会混乱,乃然能够组织良好。
所以,我认为,保持一个层次清晰的目录结构是有必要的,更何况组织一个良好的工程目录,其实是一键很简单的事情。
 
目录组织方式:
关于如何组织一个较好的python工程目录结构,已经有一些得到了共识的目录结构,在stackoverflow的这个问题上,能看到大家对python目录结构的讨论。

简要解释一下:
    1.bin/:存放项目的一些可执行文件,当然你可以起名script/之类的也行
    2.foo/:存放项目的所有源代码,1.源代码中所有模块、包都应该放在此目录。不要置于顶层目录。2.其子目录tests/存放单元测试代码 3.程序的入口最好命名为main.py
    3.docs/:存放一些文档。
    4.setup.py:安装、不熟、打包的脚本
    5.requirement。txt:存放润阿金依赖的外部python包列表
    6.readme:项目说明文件。
 
除此之外,有一些方案给出了更加多的内容。比如license.txt ,changelog。txt文件等,我没有列在这里,因为这些东西主要是项目开元的时候需要用到的。
 
关于README的内容
这个我觉得每个项目都应该有的一个文件,目的是能简要描述该项目的信息,让读者快速了解这个项目.
它需要说明一下几个事项:
1.软件定位,软件的基本功能
2.运行代码的方法:安装环境、启动命令等.
3.简要的使用说明
4.代码目录机构说明,更详细点可以说明软件的基本原理.
5.常见问题说明.
 
关于requirements.txt 和 setup.py
一般来说,用setup.py来管理diamante的打包、安装、部署问题.业界标准的写法是用python流行的打包工具setuptools来管理这些事情.这种方式普遍应用于开源项目中.不过这里的核心思想不是用标准化的工具来解决这些问题,而是说,一个项目一定要有一个安装部署工具,能够快速便捷的在一台新的机器上将环境装好、代码部署好将程序运行起来.
我刚开始接触python写项目的时候,安祖航环境、部署代码、运行程序这个过程全是手动完成,遇到以下问题:
1.安装环境时经常忘了最近又添加了一个新的python包,结果一到线上运行,程序就出错了.
2.python包的版本依赖问题,有时候我们程序中使用的是一个版本的python包,但是官方的已经是最新的包了,通过手动安装就可能装错.
3.如果依赖的包很多的话,一个一个安装这些依赖是很费时的事情.
4.新同学开始写项目的时候,将程序跑起来非常麻烦,因为可能经常忘了要怎么安装各种依赖.
 
setup.py可以将这些事情自动化起来,提高效率、减少出错的概率."复杂的东西自动化,能自动化的东西一定要自动化"是一个非常好的习惯
 setuptools的文档比较庞大,刚接触的话,可能不太好好找到切入点,学习技术的方式就是看别人怎么用的,可以参考一些python的一个web框架flask是如何写的setup.py
当然,简单点自己写个安装脚本(deploy.sh)替代setup.py也未尝不可.

requirements.txt
这个文件存在目的是:
1.方便开发者维护软件的包依赖.将开发过程中新增的包添加进这个列表中,避免在setup.py安装依赖时漏掉软件包.
2.方便读者明确项目使用了哪些python包
 
这个的格式是每一行包含一个包依赖的说明,通常是flask >= 0.10这个格式,要求是这个格式被pip识别,这样就可以简单的通过pip install -r requirements.txt 来包所有python包依赖都装好了.

python - 编程规范问题的更多相关文章

  1. Python编程规范(PEP8)

    Python编程规范(PEP8) 代码布局 缩进 对于每一次缩进使用4个空格.使用括号.中括号.大括号进行垂直对齐,或者缩进对齐. 制表符还是空格? 永远不要将制表符与空格混合使用.Python最常用 ...

  2. Python 编程规范-----转载

    Python编程规范及性能优化 Ptyhon编程规范 编码 所有的 Python 脚本文件都应在文件头标上 # -*- coding:utf-8 -*- .设置编辑器,默认保存为 utf-8 格式. ...

  3. Python编程规范及性能优化(转载)

    转载地址:http://codeweblog.com/python编程规范及性能优化/

  4. Python学习手册之 Python 之禅、Python 编程规范和函数参数

    在上一篇文章中,我们介绍了 Python 的正则表达式使用示例,现在我们介绍 Python 之禅. Python 编程规范和函数参数.查看上一篇文章请点击:https://www.cnblogs.co ...

  5. Python 编程规范梳理

    缘由 由于项目团队中新加入了几名攻城狮, 大家之前的背景各不相同,写出的代码也是“风格迥异”.正所谓:“无规则不成方圆”,因此需要对编程进行必要的规范. 整体的思路是:依照PEP8 Python 编码 ...

  6. Python 编程规范 —— TODO 注释(结合 PyCharm)

    编程是代码和注释的统一: TODO 自然表示需要做而未做的一些待完成的事项,有助于事后的检索,以及对整体项目做进一步的修改迭代. # TODO(kl@gmail.com): Use a "* ...

  7. PEP8 Python编程规范

    官方文档: https://www.python.org/dev/peps/pep-0008/ ---------------------------------------------------- ...

  8. PEP 8 python编程规范

    一 代码编排 缩进.4个空格的缩进(编辑器都可以完成此功能),不使用Tap,更不能混合使用Tap和空格. 每行最大长度79,换行可以使用反斜杠,最好使用圆括号.换行点要在操作符的后边敲回车. 类和to ...

  9. Python编程规范

    打破一条既定规则的两个理由: 应用这个规则将导致代码可读性下降. 为了和周围的代码保持一致. 编码: 所有的 Python 脚本文件都应在文件头标上如下标识或其兼容格式的标识: # -*- codin ...

随机推荐

  1. Day3--Python--字符串,for循环,迭代

    常见的基本数据类型: 1.int 整数 主要用来进行数学运算 2.bool 布尔. 判断真假. if 和 while循环中常用 3.str 字符串,一般放小量数据 4.list 列表.可以存放大量的数 ...

  2. Expected value at 1:0 异常解决方法

    有时候自己也很郁闷,明明自己写的是ok的竟然,还报错. 网上查找了这个异常,竟然没有解决方法,后来尝试着去解决,竟然真的解决了. 其实,我又新建一个文件夹,把原先的代码给粘贴复制进去就ok了,其实到现 ...

  3. JavaSE_坚持读源码_ClassLoader对象_Java1.7

    ClassLoader java.lang public abstract class ClassLoader extends Object //类加载器的责任就是加载类,说了跟没说一样 A clas ...

  4. MyBatis-DynamicSQL 动态SQL

    MyBatis 的动态 SQL 使用 OGNL 表达式 http://commons.apache.org/proper/commons-ognl/language-guide.html 在 XML ...

  5. python数据结构总结

    一.列表 1.列表脚本操作符: (1)扩增的操作符: “+”:用于组合列表:如[1,2,3]+[4,5,6]==>[1,2,3,4,5,6] "*":重复;如[2,3]*2= ...

  6. WebStorm记录(2)

    继续效果图 CSS初始化 前面理解错了,背景图应该铺满 <div class="bg"> html,body,*{ /*盒子模型使用边框模式*/ box-sizing: ...

  7. SpringBoot系列: 单元测试

    SpringBoot 项目单元测试也很方便, Web项目中单元测试应该覆盖:1. Service 层2. Controller 层 本文前半部分讲解是一些测试基础配置. 对于Service和Contr ...

  8. ElasticSearch - Shard数调优(ElasticSearch性能)

    序言 资料 https://blog.csdn.net/waneyongfu/article/details/78215972

  9. 【九】虚拟机工具 02 - jstat命令使用

    java8jstat官方文档 jstat命令可以查看堆内存各部分的使用量,以及加载类的数量.命令的格式如下: jstat [-命令选项] [vmid] [间隔时间/毫秒] [查询次数] 注意:使用的j ...

  10. 24.join算法/锁_1

    一. JOIN算法1.1. JOIN 语法 mysql> select * from t4; +---+------+ | a | b | +---+------+ | | 11 | | | 5 ...