Pythonic定义
Pythonic定义
Python最常用的编码风格还是PEP8,详见:http://jython.cn/dev/peps/pep-0008/
Pythonic确实很难定义,先简单引用下《Python之禅》中的几句经典阐释:

优美胜于丑陋(Python 以编写优美的代码为目标)
明了胜于晦涩(优美的代码应当是明了的,命名规范,风格相似)
简洁胜于复杂(优美的代码应当是简洁的,不要有复杂的内部实现)
复杂胜于凌乱(如果复杂不可避免,那代码间也不能有难懂的关系,要保持接口简洁)
扁平胜于嵌套(优美的代码应当是扁平的,不能有太多的嵌套)
间隔胜于紧凑(优美的代码有适当的间隔,不要奢望一行代码解决问题)
可读性很重要(优美的代码是可读的)

举个简单的例子,使用Pythonic风格编码的快速排序算法代码如下所示:

def quicksort(array):
less = [];
greater = []; if len(array) <= 1:
return array
pivot = array.pop()
for x in array:
if x <= pivot:
less.append(x)
else:
greater.append(x) return quicksort(less) + [pivot] + quicksort(greater)

Pythonic代码风格
- 交换两个变量
 
C语言代码如下:

1 int a = 1, b = 2;
2 int tmp = a;
3 a = b;
4 b = tmp;
5
6 //如果两个变量都为整数类型,当然也可使用:
7
8 int a = 1, b = 2;
9 a = a^b;
10 b = a^b;
11 a = a^b;
12
13 //这样的形式,可以不用引入第三个变量

Pythonic代码如下:
1 a, b = b, a
- Python可以灵活的使用迭代器,安全的关闭文件描述符,如下:
 
1 for i in alist:
2 do_sth_with(i)
3
4 with open(path, 'r') as f:
5 do_sth_with(f)
Pythonic追求的是对Python语法的充分发挥,写出的代码带Python味儿,而不是看着向C或JAVA代码;
- 不应过分使用技巧
 
1 a = [1, 2, 3, 4]
2 b = 'abcdef'
3 print a[::-1]
4 print b[::-1]
使用Python比较多的人可以比较容易看出其作用,就是输出逆序的a和b,但还是比较晦涩,Pythonic追求的是充分利用Python语法,上面代码可写为:
1 a = [1, 2, 3, 4]
2 b = 'abcdef'
3 print list(reversed(a))
4 print list(reversed(b))
- 字符串格式化
 
我们很多人一般这样写,比较简洁:
1 name = 'Tom'
2 age = '20'
3 print 'Hello %s, your age is %s !' % (name, age)
其实,%s是比较影响可读性的,尤其是数量多了之后,很难清楚哪个占位符对应哪个实参,比较Pythonic的代码如下:
1 value = {'name': 'Tom', 'age': '20'}
2 print 'Hello %(name)s, your age is %(age)s !' % value
使用%占位符的形式,依旧不是Python最推荐的,最具Pythonic风格的代码如下:
1 print 'Hello {name}, your age is {age} !'.format(name = 'Tom', age = '20')
str.format()是Python最为推荐的字符串格式化方法;
- 包和模块
 
包和模块的命名采用小写、单数形式,而且短小;
包通常仅作为命名空间,可以只包含空的__init__.py文件;
- 过多的if...elif...elif......else...应使用字典来实现
 

1 if n == 0:
2 print "You typed zero..."
3 elif n == 1:
4 print "You are in top..."
5 elif n == 2:
6 print "n is even number..."
7 else:
8 print "Default value"
9
10 # 使用字典来实现更好一些
11
12 def f(x):
13 return {
14 0: "You typed zero...",
15 1: "You are in top...",
16 2: "n is even number...",
17 }.get(x, "Default value")

编写Pythonic代码
避免劣化代码
- 避免只用大小写来区分不同的对象;
 - 避免使用容易引起混淆的名称,变量名应与所解决的问题域一致;
 - 不要害怕过长的变量名;
 
代码中添加适当注释
- 行注释仅注释复杂的操作、算法,难理解的技巧,或不够一目了然的代码;
 - 注释和代码要隔开一定的距离,无论是行注释还是块注释;
 - 给外部可访问的函数和方法(无论是否简单)添加文档注释,注释要清楚地描述方法的功能,并对参数,返回值,以及可能发生的异常进行说明,使得外部调用的人仅看docstring就能正确使用;
 - 推荐在文件头中包含copyright申明,模块描述等;
 - 注释应该是用来解释代码的功能,原因,及想法的,不该对代码本身进行解释;
 - 对不再需要的代码应该将其删除,而不是将其注释掉;
 
适当添加空行使代码布局更为优雅、合理
- 在一组代码表达完一个完整的思路之后,应该用空白行进行间隔,推荐在函数定义或者类定义之间空两行,在类定义与第一个方法之间,或需要进行语义分隔的地方空一行,空行是在不隔断代码之间的内在联系的基础上插入的;
 - 尽量保证上下文语义的易理解性,一般是调用者在上,被调用者在下;
 - 避免过长的代码行,每行最好不要超过80字符;
 - 不要为了保持水平对齐而使用多余的空格;
 
编写函数的几个原则
- 函数设计要尽量短小,嵌套层次不宜过深;
 - 函数申明应做到合理、简单、易于使用,函数名应能正确反映函数大体功能,参数设计应简洁明了,参数个数不宜过多;
 - 函数参数设计应考虑向下兼容;
 - 一个函数只做一件事,尽量保证函数语句粒度的一致性;
 
将常量集中到一个文件
Python没有提供定义常量的直接方式,一般有两种方法来使用常量;
- 通过命名风格来提醒使用者该变量代表的意义为常量,如常量名所有字母大写,用下划线连接各个单词,如MAX_NUMBER,TOTLE等;
 - 通过自定义的类实现常量功能,常量要求符合两点,一是命名必须全部为大写字母,二是值一旦绑定便不可再修改;
 

1 class _const:
2
3 class ConstError(TypeError): pass
4 class ConstCaseError(ConstError): pass
5
6 def __setattr__(self, name, value):
7 if name in self.__dict__:
8 rasie self.ConstError, "Can't change const.%s" % name
9 if not name.isupper():
10 raise self.ConstCaseError, "const name '%s' is not all uppercase" % name
11
12 self.__dict__[name] = value
13
14 import sys
15 sys.modules[__name__] = _const()
Pythonic定义的更多相关文章
- Python常见编程规范总结
		
Pythonic定义 Python最常用的编码风格还是PEP8,详见:http://jython.cn/dev/peps/pep-0008/ Pythonic确实很难定义,先简单引用下<Pyth ...
 - 超文本传输协议-HTTP/1.1
		
超文本传输协议-HTTP/1.1(修订版) ---译者:孙超进本协议不限流传发布.版权声明Copyright (C) The Internet Society (1999). All Rights R ...
 - python gui之tkinter界面设计pythonic设计
		
ui的设计,控件id的记录是一件比较繁琐的事情. 此外,赋值和读取数据也比较繁琐,非常不pythonic. 有没有神马办法优雅一点呢?life is short. 鉴于控件有name属性,通过dir( ...
 - Be Pythonic ,Google Python Style Guide
		
为了更规范的写代码,变得更专业 分号 1 不在句末添加分号,不用分号在一行写两句代码 行长度 2 每行不超过80字符,python会隐式行连接圆括号,中括号,花括号中的字符,如多参数方法调用可以写为多 ...
 - [Python]更加Pythonic的多个List合并和Python的安利
		
原题: https://segmentfault.com/q/1010000005904259 问题: 倘若存在 L=[ [1,2,3],[4,5,6],[7,8,9]] 这样的列表,如何把合并成[1 ...
 - Pythonic到底是什么玩意儿?
		
http://blog.csdn.net/gzlaiyonghao/article/details/2762251 作者:Martijn Faassen 译者:赖勇浩(http://blog.csdn ...
 - python pythonic是什么?
		
原文地址:http://faassen.n--tree.net/blog/view/weblog/2005/08/06/0 注:Martijn 是 Zope 领域的专家,他为 Zope 系列产品做了许 ...
 - 为Pythonic论坛添加一个“专题”功能(续)
		
上篇博文<为Pythonic论坛添加一个“专题”功能>,在模板的层次上对发帖进行了限制.也就是根据用户是否拥有权限来决定是否显示发帖框. 但是自从这么“投机取巧”的写完模板后,整夜辗转反侧 ...
 - Pythonic论坛怪怪的’居民’显示[已解决]
		
之前使用Pythonic搭建的论坛people界面显示有点问题 第一个用户不显示,问了下作者,作者回复说这个Link只有~/people/而没有用户名 就点到为止了. 按说我使用syncdb同步时注册 ...
 
随机推荐
- LVS系列一、LVS集群-NAT模式
			
一. 集群概述 1. 什么是集群? 一组各自相互独立且又相互依赖的,通过高速网络互联的计算机组成的一个计算机组, 以单一的系统模式加以管理, 为用户提供服务, 对用户来说, 用户只会认为对方是一个服务 ...
 - Jmeter启动报错解决方案
			
安装好jmeter之后在启动Jmeter的过程中出现了如下的报错信息(大部分的原因是配置不对): /usr/local/Cellar/jmeter/5.1.1/libexec/bin/jmeter: ...
 - 架构模式: Saga
			
架构模式: Saga 上下文 您已应用每服务数据库模式.每个服务都有自己的数据库.但是,某些业务事务跨越多个服务,因此您需要一种机制来确保服务之间的数据一致性.例如,假设您正在建立一个客户有信用额度的 ...
 - K8S知识点总结
			
一.K8S介绍: Kubernetes(k8s)是Google开源的容器集群管理系统.在Docker技术的基础上,为容器化的应用提供部署运行.资源调度.服务发现和动态伸缩等一系列完整功能,提高了大规模 ...
 - Kafka如何保证百万级写入速度以及保证不丢失不重复消费
			
一.如何保证百万级写入速度: 目录 1.页缓存技术 + 磁盘顺序写 2.零拷贝技术 3.最后的总结 “这篇文章来聊一下Kafka的一些架构设计原理,这也是互联网公司面试时非常高频的技术考点. Kafk ...
 - odoo10实现单点登陆绕过登陆集成页面
			
背景:由于需要集成odoo平台在其他页面,需要绕开登陆. 解决办法:开辟一个自动登陆的路由用与集成页面. 1.修改web模块中controller/main.py文件,在class名字为Home中添加 ...
 - YAPTCHA(HDU2973)【威尔逊定理】
			
威尔逊原理.即对于素数p,有(p-1)!=-1( mod p). 首先,将原式变形为[ (3×k+6)! % (3×k+7) + 1] / (3×k+7),所以: 1.3×k+7是素数,结果为1, 2 ...
 - sqlalchemy定义mysql时间戳字段
			
update_time = Column(TIMESTAMP, nullable=False, comment='更新时间戳', server_default=text('CURRENT_TIMEST ...
 - 【hash+二分】Antisymmetry
			
[题目链接] https://loj.ac/problem/2452 [参考博客] https://blog.csdn.net/xgc_woker/article/details/82904631 [ ...
 - k8s-高可用架构设计
			
docker的私有仓库harbor.容器化kubernetes部分组建.使用阿里云日志服务收集日志. 部署完成后,你将理解系统各组件的交互原理,进而能快速解决实际问题,所以本文档主要适合于那些有一定k ...