软件目录结构规范
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. IDEA或Webstorm设置Ctrl+滚轮调整字体大小

    按Ctrl+Shift+A,出现搜索框 输入mouse: 点击打开这个设置:勾选 点击ok,之后就可以通过Ctrl+滚轮 调整字体大小了.

  2. java的抽象方法

    抽象类所起的功能就像定义模板的功能,子类必须继承抽象类,因此不能用final修饰 http://blog.csdn.net/wei_zhi/article/details/52736350 抽象类的函 ...

  3. Codeforces Round #523 (Div. 2)

    Codeforces Round #523 (Div. 2) 题目一览表 来源 考察知识点 完成时间 A Coins cf 贪心(签到题) 2018.11.23 B Views Matter cf 思 ...

  4. JS实现选择排序

    function selectSort(arr){ var len=arr.length; var temp; for(var i=0;i<len-1;i++){ for(var j=i+1;j ...

  5. Python 的内置函数

    函数 功能 示例 示例结果 abs(x) 返回x的绝对值 abs(-2) 2 chr(x) 返回整数x所代表的字符 chr(65) A divmod(x,y) 返回x除以y的商和余数的元组 divmo ...

  6. mysql 将一张表的数据更新到另外一张表中

    update 更新表 set 字段 = (select 参考数据 from 参考表 where  参考表.id = 更新表.id); update table_2 m  set m.column = ...

  7. python OrderDict

    # encoding: utf-8 import csv import collections d = {'banana':3,'apple':4,'pear':1,'orange':2} print ...

  8. python如何直接控制鼠标键盘

    一.简介 我们知道在windows下输入:win + r,会弹出下面的窗口,而在下面的窗口出现后我们接着按下esc键,下面的窗口会消失 现在设想我们想在python代码里控制键盘,想通过运行代码-&g ...

  9. python第三次周末大作业

    ''' s18第三周周末⼤作业 模拟博客园系统: 1. 启动程序, 显⽰菜单列表 菜单: 1. 登录 2. 注册 3. ⽂章 4. ⽇记 5. 退出 2. ⽤户输入选项, ⽂章和⽇记必须在登录后才可以 ...

  10. golang channle close() x,ok := <- c

    close为内置函数 close内置函数关闭一个通道channle,其效果为:在最后的值从已关闭的信道中被接收后,任何对其的接收操作都会无阻塞的成功.对于已关闭的信道使用v,ok := <-   ...