Pocoo风格行为大赏

简介: Pocoo风格行为大赏

「无规矩不成方圆」Python 官方为所有开发人员制定了一套编码规范 - PEP 8。然而大部分研发团队并没有满足于此,就如同 Flask 框架的开发团队 Pocoo ,基于 PEP 8 进行调整扩充,形成了一套新的编码风格。如果你的项目正好使用了此框架,强烈建议仔细阅读。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

1.整体布局

1) 缩进采用4个空格,而非制表符( Tab 键)

2) 每行代码的长度不应该超过84个字符,最好保持在79个以内

可以通过 breakcontinuereturn 等关键字避免层层嵌套,既保持代码的美观,又提升可读性(不必左右拉取进度条)。

3) 如果代码超过如何续行?可以尝试反斜杠 \ ,如下方的示例:

this_is_a_very_long(function_call, 'with many parameters') \
    .that_returns_an_object_with_an_attribute
MyModel.query.filter(MyModel.scalar > 120) \
             .order_by(MyModel.name.desc()) \
             .limit(10)
this_is_a_very_long(function_call, 'with many parameters',
                    23, 42, 'and even more')
items = [
    'this is the first', 'set of items', 'with more items',
    'to come in this line', 'like this'
]

注意:为了保持美观,可以将链式调用中每个方法前的点 . 对齐;如果是括号内的换行,请将下一行与上一行的括号对齐,不需要使用续行符号;如果字典、列表、元祖内元素超级多,在起始括号后立即换行。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

4) 顶层函数和类由两个空行分隔,其它一个空行。不要使用过多空行来分隔代码逻辑段。例如:

def hello(name):
    print 'Hello %s!' % name
def goodbye(name):
    print 'See you %s.' % name
class MyClass(object):
    """This is a simple docstring"""
    def __init__(self, name):
        self.name = name
    def get_annoying_name(self):
        return self.name.upper() + '!!!!111'

2.表达式与代码语句

2.1 常规空格规则

1) 不是关键词的一元运算符不使用空格(例如: -~ 等等),对于圆括号也是这样。

2) 用空格包围二元运算符。

对:

exp = -1.05
value = (item_value / item_count) * offset / exp
value = my_list[index]
value = my_dict['key']

错:

exp = - 1.05
value = ( item_value / item_count ) * offset / exp
value = (item_value/item_count)*offset/exp
value=( item_value/item_count ) * offset/exp
value = my_list[ index ]
value = my_dict ['key']

2.2 禁止 Yoda 语句

永远不要用变量来比较常量,而是用常量来比较变量:

对:

if method == 'md5':
    pass

错:

if 'md5' == method:
    pass

2.3 比较

1) 针对任意类型使用 ==!=

2) 针对单一类型使用 isis not(例如: foo is not None

3) 永远不要与 TrueFalse 作比较(例如永远不要写 foo == False ,而应当写 not foo更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

2.4 排除检验

使用 foo not in bar 而不是 not foo in bar

2.5 实例检验

使用 isinstance(a, C) 而不是 type(A) is C ,但是通常应当避免检验实例,而应当检验特性。

3.命名

1) 类名采用大驼峰: CamelCase ,缩写词大写( HTTPWriter 而不是 HttpWriter

2) 变量名采用下划线连接: lowercase_with_underscores

3) 方法和函数名采用下划线连接: lowercase_with_underscores

4) 常量全部大写并采用下划线连接: UPPERCASE_WITH_UNDERSCORES

5) 预编译正则表达式: name_re

被保护的成员以单个下划线作为前缀,混合类则使用双下划线。

如果使用关键字作为类的名称,那么在名称末尾添加下划线。与内置构件冲突是允许的,请一定不要用 在变量名后添加下划线 的方式解决冲突。如果函数需要访问一个隐蔽的内置构件,请重新绑定内置构件到一个不同的名字。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

3.1 函数和方法参数

1) 类方法: cls 作为第一个参数

2) 实例方法: self 作为第一个参数

3) 用于属性的 lambda 表达式应该把第一个参数替换为 x , 像下方代码一样:


display_name = property(lambda x: x.real_name or x.username)

4.文档字符串

4.1 文档字符串约定

所有的文档字符串为 Sphinx 可理解的 reStructuredText 格式。它们的形态 因行数不同而不同。如果只有一行,三引号闭合在同一行,否则开头的三引号与文本在同一行,结尾的三引号独立一行:

def foo():
    """This is a simple docstring"""
def bar():
    """This is a longer docstring with so much information in there
    that it spans three lines.  In this case the closing triple quote
    is on its own line.
    """

4.2 模块首行

模块首行包含一个 utf-8 编码声明(即使没有使用非 ASCII 字符,也始终推荐这么做)和一个标准的文档字符串:

# -*- coding: utf-8 -*-
"""
    package.module
    ~~~~~~~~~~~~~~
    A brief description goes here.
    :copyright: (c) YEAR by AUTHOR.
    :license: LICENSE_NAME, see LICENSE_FILE for more details.
"""

谨记使用合适的版权和许可证文件以利于通过 Flask 扩展审核。

5.注释

注释的规则与文档字符串类似。两者都使用 reStructuredText 格式。如果一个 注释被用于一个说明类属性,在起始的井号( # )后加一个冒号:

class User(object):
    #: the name of the user as unicode string
    name = Column(String)
    #: the sha1 hash of the password + inline salt
    pw_hash = Column(String)

翻译自官方文档 https://flask.palletsprojects.com/en/1.0.x/styleguide/

相关文章
|
5月前
首途第三十三套清新简约卡片风格蓝紫渐变色短视频模板 | 苹果CMSV10主题
首途第三十三套清新简约卡片风格蓝紫渐变色短视频模板 | 苹果CMSV10主题 我们的简约风格,以纯洁的白色和深邃的紫色为主色调,为您提供了一种清新、时尚的浏览体验。在这个简洁而美丽的界面中,您可以轻松畅享各种精彩短视频。我们专注于简单的设计,使用户能够轻松找到他们喜欢的内容,而不受繁杂的界面干扰。紫色的调性为网页增添了一抹神秘和优雅,让您在欣赏视频的同时感受到一份宁静和舒适。清晰的布局和直观的操作,让您可以更专注于视频内容,而不被复杂的功能所困扰
60 1
妙笔生词智能作词软件能写什么类型风格的歌词
**妙笔生词软件**是出色的歌词创作工具,擅长多种风格如流行、民谣、摇滚、中国风等,还能按用户需求定制特定风格,包括嘻哈、儿歌、企业歌等,满足广泛创作需求。
|
5月前
|
算法 程序员 UED
探索代码的诗意:编程中的创意与美学
【6月更文挑战第4天】在数字世界的编织中,代码不仅仅是冷冰冰的指令集。它们像诗人的笔触,绘制出技术与艺术交融的画卷。本文将带你走进编程的深层次美感,探讨如何在逻辑的严谨与创意的自由间找到平衡,以及这种平衡如何激发技术创新和提升用户体验。
56 0
|
安全 iOS开发
让人惊艳的高级配色,让你的色彩灵感爆棚!
让人惊艳的高级配色,让你的色彩灵感爆棚!
82 0
|
机器学习/深度学习 编解码 数据可视化
生成你的漫画形象! 漫画风格迁移神器 AnimeGANv2
趁着有空的时间,给大家介绍一些有趣的项目吧,比如这个漫画风格迁移神器 AnimeGANv2,可以快速生成自己的漫画形象 动漫是我们日常生活中常见的艺术形式,被广泛应用于广告、电影和儿童教育等多个领域。目前,动漫的制作主要是依靠手工实现。然而,手工制作动漫非常费力,需要非常专业的艺术技巧。对于动漫艺术家来说,创作高质量的动漫作品需要仔细考虑线条、纹理、颜色和阴影,这意味着创作动漫既困难又耗时。因此,能够将真实世界的照片自动转换为高质量动漫风格图像的自动技术是非常有价值的。它不仅能让艺术家们更多专注于创造性的工作,也能让普通人更容易创建自己的动漫作品。
生成你的漫画形象! 漫画风格迁移神器 AnimeGANv2
|
API
《超越平凡的平面设计: 版式设计原理与应用》—怎样运用对比确定字体风格
<span style='letter-spacing:1px'>本节书摘来自异步社区《超越平凡的平面设计: 版式设计原理与应用》一书中的怎样运用对比确定字体风格,作者【美】John McWade,更多章节内容可以访问云栖社区“异步社区”公众号查看。</span>
1913 0
《超越平凡的平面设计: 版式设计原理与应用》—怎样用好字体
<span style='letter-spacing:1px'>本节书摘来自异步社区《超越平凡的平面设计: 版式设计原理与应用》一书中的怎样用好字体,作者【美】John McWade,更多章节内容可以访问云栖社区“异步社区”公众号查看。</span>
1899 0
下一篇
无影云桌面