- 27
- 0
- 约5.16千字
- 约 5页
- 2018-04-17 发布于河南
- 举报
Python 编程规范
Python 编程规范编码??? 所有的 Python 脚本文件都应在文件头标上 # -*- coding:utf-8 -*- 。设置编辑器,默认保存为 utf-8 格式。注释??? 业界普遍认同 Python 的注释分为两种的概念,一种是由 # 开头的“真正的”注释,另一种是 docstrings。前者表明为何选择当前实现以及这种实现的原理和难点,后者表明如何使用这个包、模块、类、函数(方法),甚至包括使用示例和单元测试。??? 坚持适当注释原则。对不存在技术难点的代码坚持不注释,对存在技术难点的代码必须注释。但与注释不同,推荐对每一个包、模块、类、函数(方法)写 docstrings,除非代码一目了然,非常简单。缩进??? Python 依赖缩进来确定代码块的层次,行首空白符主要有两种:tab 和空格,但严禁两者混用。如果使用 tab 缩进,设定 tab 为 4 个空格。??? 公司内部推荐使用 4 个空格的 tab 进行缩进。空格??? 空格在 Python 代码中是有意义的,因为 Python 的语法依赖于缩进,在行首的空格称为前导空格。在这一节不讨论前导空格相关的内容,只讨论非前导空格。非前导空格在 Python 代码中没有意义,但适当地加入非前导空格可以增进代码的可读性。1)?在二元算术、逻辑运算符前后加空格:如 a = b + c;2)?在一元前缀运算符后不加空格,如 if !flg: pass;3)?“:”用在行尾时前后皆不加空格,如分枝、循环、函数和类定义语言;用在非行尾时两端加空格,如 dict 对象的定义 d = {‘key’ : ’value’}。4)?括号(含圆括号、方括号和花括号)前后不加空格,如 do_something(arg1, arg2),而不是 do_something( arg1, arg2 );5)?逗号后面加一个空格,前面不加空格;s空行??? 适当的空行有利于增加代码的可读性,加空行可以参考如下几个准则:1)?在类、函数的定义间加空行;2)?在 import 不同种类的模块间加工行;3)?在函数中的逻辑段落间加空行,即把相关的代码紧凑写在一起,作为一个逻辑段落,段落间以空行分隔;断行??? 尽管现在的宽屏显示器已经可以单屏显示超过 256 列字符,但本规范仍然坚持行的最大长度不得超过 78 个字符的标准。折叠长行的方法有以下几种方法:1)?为长变量名换一个短名,如:??? this.is.a.very.long.variable_name = this.is.another.long.variable_name??? 应改为:??? variable_name1 = this.is.a.very.long.variable_name??? variable_name2 = this.is.another.variable_name??? variable_name1 = variable_name2s2)?在括号(包括圆括号、方括号和花括号)内换行,如:??? class Edit(CBase):??????? def __init__(self, parent, width,???????????????????????????????? font = FONT, color = BLACK, pos = POS, style = 0):??? 或:??? very_very_very_long_variable_name = Edit(parent, \??????????????????????????????????????????????????????????????????????????? width, \??????????????????????????????????????????????????????????????????????????? font, \??????????????????????????????????????????????????????????????????????????? color, \??????????????????????????????????????????????????????????????????????????? pos)??? 如果行长到连第一个括号内的参数都放不下,则每个元素都单独占一行:??? very_very_very_long_variable_name = ui.widgets.Edit( \???????????????????????????????????????????????
您可能关注的文档
- 实习基地建设(公司名称).doc
- 思想汇报2 面对就业.doc
- 2005驻村工作计划.doc
- 如何选择适合的销售渠道.doc
- 计算机基础原理7.ppt
- 城院述职20110901.doc
- JAVA WEb从入门到精通 第十四章04 文件输入输出流.ppt
- 任务驱动教学模式在中小学信息技术课的应用研究.doc
- 公司质量管理奖惩方法.doc
- 我国零售业运用电子商务的现状.doc
- 2025年版汽车趋势报告 The 2025 EPA Automotive Trends Report.docx
- 2026年边缘计算开源平台EdgeX Foundry入门与二次开发.docx
- 2026年超声内镜放大内镜早癌诊断AI辅助识别系统临床评价.docx
- 2026年报废汽车回收与再制造逆向物流体系.docx
- 2026年产品碳足迹核算方法学:从摇篮到大门与从摇篮到坟墓.docx
- 2026年城乡要素平等交换双向流动政策创新试点申报材料.docx
- 2026年超导半导体接口电路架构与电平转换驱动器设计.docx
- 2026年财政贴息不再以再贷款支持为前提后的风险防范与合规要点.docx
- 2026年不动产信托登记试点政策对遗嘱信托支持.docx
- 2026年城乡有机废弃物协同处理技术方案.docx
原创力文档

文档评论(0)