如何编写高质量的python程序

python有专门的模块打包系统distutils,你可以用这套机制把你的代码打包并分发到Pypi上,这样任何人都可以用pip或easy_install安装你的模块。如果你开发的是内部项目,还可以用mypypi架设私有的pypi,然后把项目的大的版本更新发布到内部的pypi上,配置管理人员和运维人员可以很方便的从pypi上拉取代码安装到...
如何编写高质量的python程序
写出规范的代码是写出高质量代码的第一步,并且有助于培养仔细的习惯。

为了培养规范写代码的习惯,可以安装flake8这个工具,它不仅可以检查代码风格是否符合官方建议(PEP8),而且还能找出潜在的隐患(用Pyflakes做语法分析),更逆天的是还能检测到你有些函数写的太复杂(代码圈复杂度)了,更更逆天的是可以设置git commit之前必须通过这些检查。

当然具体操作需要根据自己的项目进行一些定制,比如可以忽略E501,W293。

空白项目模版

好的开始是成功的一半,写python代码就从pyempty开始吧。

在github上看一下那些经典的项目,web.py,flask, pep8,他们的项目目录都很规范,综合借鉴了一些项目的特点,我写了这个pyempty项目。

1.README.md 这里写你项目的简介,quick start等信息,虽然distutils要求这个文件没有后缀名,但github上如果后缀是.md的话可以直接转换成html显示。

2.ChangeLog.txt 该文件存放程序各版本的变更信息,也有一定的格式,参考web.py的ChangeLog.txt

3.LICENES.txt 这里存放你项目使用的协议,不要编写自己的协议。

4.requirements.txt 如果你的项目需要依赖其它的python第三方库,在这里一行一个写出来,可能pip install的时候能自动帮你安装

5.setup.py 安装脚本,后面详细介绍

6.docs 里面存放你的项目文档,如概要设计,详细设计,维护文档,pydoc自动生成的文档等,强烈推荐大家使用MarkDown格式编写文档

7.src 这个目录里存放项目模块的主要代码,尽量不要把模块目录直接放到根目录,模块代码目录可以在setup.py里指定的

8.tests 这个目录存放所有单元测试,性能测试脚本,单元测试的文件确保以test_做前缀,这样distutils会自动打包这些文件,并且用python -m unittest discover -s ./ -p 'test_*.py' -v 可以直接执行这些测试

单元测试

Martin Fowler:"在你不知道如何测试代码之前,就不该编写程序。而一旦你完成了程序,测试代码也应该完成。除非测试成功,你不能认为你编写出了可以工作的程序。"

我们有很多理由不写单元测试,归根结底是懒,虽然代码大全上说:

大部分研究都发现,检测比测试的成本更小。NASA软件工程实验室的一项研究发现,阅读代码每小时能够检测出来的缺陷要比测试高出80%左右(Basili and Selby 1987)。后来,IBM的一项研究又发现,检查发现的一个错误只需要3.5个工作时,而测试则需要花费15-25个工作时(Kaplan 1995)。

但是单元测试还是让别人相信你的代码有很高质量的最有力证据。

好了,请详细阅读:

深入python3.0: 单元测试-2.x也适用

Unit testing framework 不完整中文版

文档

敏捷开发不是提倡什么文档也不写,没有文档就没有传承和积累,轮岗或新人接手任务就会遇到很大的麻烦,所以我决定每个项目最少要写以下文档:

1.nalysis.model.md 概要设计文档,不同于README.md文件,该文档应该写于项目开发之前,把项目有哪些功能,大概分几个模块等项目整体概述信息写一下。

2.design.model.md 详细设计文档,不用太详细,至少把项目依赖哪些东西,谁依赖这个项目,重要算法流程描述,代码整体结构等写出来。

3.maintain.md 维护文档,这个我觉得最重要,你的服务都记录哪些日志,需要监控哪些业务指标,如何重启,有哪些配置项等,没这些东西,你的项目很难运维。

上面这些文档都是项目全局性的文档,不适合写在docstring或注视里,所以要有单独的文档。

打包

python有专门的模块打包系统distutils,你可以用这套机制把你的代码打包并分发到Pypi上,这样任何人都可以用pip或easy_install安装你的模块。

如果你开发的是内部项目,还可以用mypypi架设私有的pypi,然后把项目的大的版本更新发布到内部的pypi上,配置管理人员和运维人员可以很方便的从pypi上拉取代码安装到测试环境或生产环境。

发布大版本的时候要给版本命名及编写ChangeList,可以参考Git Pro的相关章节,主要记住以下几个命令。

git tag -a v0.1 -m 'my test tag' #给大版本命名,打Tag
git describe master #给小版本命名,Git将会返回一个字符串,由三部分组成:最近一次标定的版本号,加上自那次标定之后的提交次数,再加上一段SHA-1值
git shortlog --no-merges master --not v0.1 #生成版本简报,ChangeList
python有自己的打包机制,所以一般不要用git archive命令。

当然大版本管理用pypi管理比较合适,小的bug fix,紧急上线等好多公司都是用git直接从生产环境拉代码更新,因为git,svn等可以很方便的撤销某次更新,回滚到某个位置。

如何管理好大版本上线和小的紧急上线,我还没理清思路,欢迎大家参与讨论。

关于打包,请阅读如下链接:

Python 打包指南

深入Python3.0:打包 Python 类库

python打包:分发指定文件

出自:http://developer.51cto.com/art/201209/356603.htm2015-01-28
mengvlog 阅读 34 次 更新于 2025-09-11 12:28:54 我来答关注问题0
  •  赛玖久生活日记 EffectivePython编写高质量代码3-使用支持插值的f-string与str.format方法

    f-string:是Python 3.6及更高版本中推荐的字符串格式化方式。它简洁、易读且功能强大,特别适用于需要嵌入表达式或进行简单格式化的场景。在编写高质量代码时,应根据具体需求选择合适的字符串格式化方式。对于简单的字符串拼接和格式化,f-string通常是更好的选择;而对于需要复杂格式化选项或处理多个占位符...

  •  誉祥祥知识 总结90条写Python程序的建议,送给初学者!

    优先使用absolute import:在Python 3中,优先使用absolute import导入模块。理解i+=1与++i的区别:在Python中,++i并不表示自增操作,而是表示正数。使用with语句:习惯使用with语句自动关闭资源,特别是在文件读写中。使用else子句简化循环:在循环中使用else子句处理循环正常结束的情况。异常处理原则:注意...

  • Python编写桌面程序主要有以下几种途径:使用Tkinter模块:简介:Tkinter是Python自带的一个GUI工具包,允许用户创建基本的GUI界面,如窗口、按钮、文本框等。优点:易于上手,适合快速开发简单的桌面应用程序。示例:可以通过简单的代码实现窗口、按钮等控件的创建,并添加事件处理逻辑。使用PyQt:简介:PyQt是基...

  •  文暄生活科普 如何用Python编写应用程序

    一、安装Python环境 首先,需要在计算机上安装Python编译器。通常,只需将Python安装包下载后,双击打开并按照默认方式安装即可。安装完成后,在开始菜单中可以找到IDLE(Python的集成开发环境)的快捷方式。IDLE是一个简单的文本编辑器,适合初学者编写和运行Python代码。二、编写Python代码 打开IDLE:点击开始...

  • 用Spyder写Python程序的要点如下:安装Spyder:Spyder是一个开源的科学计算集成开发环境(IDE),支持Python编程。可以通过Anaconda发行版来安装Spyder,因为Anaconda包含了Spyder及其依赖的大量科学计算库。如果已经安装了Anaconda,可以直接在Anaconda Navigator中启动Spyder。配置Spyder:打开Spyder后,可以在“...

檬味博客在线解答立即免费咨询

Python相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部