如何让你的Python代码更加pythonic ?

pythonic如果翻译成中文的话就是很python。很+名词结构的用法在中国不少。

以下为了简略,我们用P表示pythonic的写法,NP表示non-pythonic的写法,当然此P-NP非彼P-NP。

为什么要追求pythonic?

相比于NP,P的写法简练,明确,优雅,绝大部分时候执行效率高,代码越少也就越不容易出错。我认为好的程序员在写代码时,应该追求代码的正确性,简洁性和可读性,这恰恰就是pythonic的精神所在。

对于具有其他编程语言经验而初涉Python的程序员(比如我自己)来说,在写Python代码时,认识到pythonic的写法,会带来更多的便利和高效,而本文的主要读者也将是这群程序员。

以下将给出P和NP的n种示例,供读者参考,查阅。

P vs. NP的示例

链式比较

P:


1

2

3

= 3

= 1

1 <= b <= a < 10  #True

NP:


1

2

3

= 3

= 1

b >= 1 and b <= and a < 10 #True

P是小学生都能看懂的语法,简单直接省代码~

真值测试

P:


1

2

3

4

5

6

name = ‘Tim‘

langs = [‘AS3‘‘Lua‘‘C‘]

info = {‘name‘‘Tim‘‘sex‘‘Male‘‘age‘:23 }    

 

if name and langs and info:

    print(‘All True!‘)  #All True!

NP:


1

2

if name != ‘‘ and len(langs) > 0 and info != {}:

    print(‘All True!‘#All True!

简而言之,P的写法就是对于任意对象,直接判断其真假,无需写判断条件,这样既能保证正确性,又能减少代码量。

真假值表(记住了假你就能省很多代码!)

真     假

True     False

任意非空字符串 空的字符串 ‘‘

任意非0数字 数字0

任意非空容器 空的容器 [] () {} set()

其他任意非False None

字符串反转

P:


1

2

def reverse_str( s ):

    return s[::-1]

NP:


1

2

3

4

5

def reverse_str( s ):

    = ‘‘

    for in xrange(len(s)-1,-1,-1):

        += s[x]

    return t

P的写法简单,经测试,效率也更好。

如果用于检测回文,就是一句话input == input[::-1],多么的优雅!

字符串列表的连接

P:


1

2

3

strList = ["Python""is""good"]  

 

res =  ‘ ‘.join(strList) #Python is good

NP:


1

2

3

4

5

res = ‘‘

for in strList:

    res += + ‘ ‘

#Python is good

#最后还有个多余空格

string.join()常用于连接列表里的字符串,相对于NP,P的方式十分高效,且不会犯错。

列表求和,最大值,最小值,乘积

P:


1

2

3

4

5

6

numList = [1,2,3,4,5]   

sum = sum(numList)  #sum = 15

maxNum = max(numList) #maxNum = 5

minNum = min(numList) #minNum = 1

from operator import mul

prod = reduce(mul, numList, 1#prod = 120 默认值传1以防空列表报错

NP:


1

2

3

4

5

6

7

8

9

10

11

12

sum = 0

maxNum = -float(‘inf‘)

minNum = float(‘inf‘)

prod = 1

for num in numList:

    if num > maxNum:

        maxNum = num

    if num < minNum:

        minNum = num

    sum += num

    prod *= num

# sum = 15 maxNum = 5 minNum = 1 prod = 120

经简单测试,在numList的长度为10000000时,在我的机器上对列表求和,P耗时0.6s,NP耗时1.3s,将近两倍的差距。所以不要自己造轮子了。

列表推导式

P:


1

2

= [x*for in range(10if % 3 == 0]

#l = [0, 9, 36, 81]

NP:


1

2

3

4

5

= []

for in range(10):

    if % 3 == 0:

        l.append(x*x)

#l = [0, 9, 36, 81]

你看,使用P的列表推导式,构建新列表变得多么简单直观!

字典的默认值

P:


1

2

3

4

dic = {‘name‘:‘Tim‘‘age‘:23}  

 

dic[‘workage‘= dic.get(‘workage‘,0+ 1

#dic = {‘age‘: 23, ‘workage‘: 1, ‘name‘: ‘Tim‘}

NP:


1

2

3

4

5

if ‘workage‘ in dic:

    dic[‘workage‘+= 1

else:

    dic[‘workage‘= 1

#dic = {‘age‘: 23, ‘workage‘: 1, ‘name‘: ‘Tim‘}

dict的get(key,default)方法用于获取字典中key的值,若不存在该key,则将key赋默认值default。

P相比NP的写法少了if...else...,实乃痛恨if...else...之人首选!

for…else…语句

P:


1

2

3

4

5

6

7

for in xrange(1,5):

    if == 5:

        print ‘find 5‘

        break

else:

    print ‘can not find 5!‘

#can not find 5!

NP:


1

2

3

4

5

6

7

8

9

find = False

for in xrange(1,5):

    if == 5:

        find = True

        print ‘find 5‘

        break

if not find:

    print ‘can not find 5!‘

#can not find 5!

for...else...的else部分用来处理没有从for循环中断的情况。有了它,我们不用设置状态变量来检查是否for循环有break出来,简单方便。

三元符的替代

P:


1

2

3

4

= 3

 

= 2 if a > 2 else 1

#b = 2

NP:


1

2

3

4

5

if a > 2:

    = 2

else:

    = 1

#b = 2

如果你具备C的编程经验,你就会寻找A ? B : C的替代品。你可能发现A and B or C看起来还不错,但是b = a > 1 and False or True会返回True,而实际意图应该返回False。

使用b = False if a > 1 else True则会正确返回False,所以它才是正宗的三元符替代品。

Enumerate

P:


1

2

3

4

5

6

7

8

9

array = [12345]

 

for i, e in enumerate(array,0):

    print i, e

#0 1

#1 2

#2 3

#3 4

#4 5

NP:


1

2

3

4

5

6

7

for in xrange(len(array)):

    print i, array[i]

#0 1

#1 2

#2 3

#3 4

#4 5

使用enumerate可以一次性将索引和值取出,避免使用索引来取值,而且enumerate的第二个参数可以调整索引下标的起始位置,默认为0。

使用zip创建键值对

P:


1

2

3

4

5

keys = [‘Name‘‘Sex‘‘Age‘]

values = [‘Tim‘‘Male‘23]

 

dic = dict(zip(keys, values))

#{‘Age‘: 23, ‘Name‘: ‘Tim‘, ‘Sex‘: ‘Male‘}

NP:


1

2

3

4

dic = {}

for i,e in enumerate(keys):

    dic[e] = values[i]

#{‘Age‘: 23, ‘Name‘: ‘Tim‘, ‘Sex‘: ‘Male‘}

zip方法返回的是一个元组,用它来创建键值对,简单明了。

时间: 2024-10-24 03:19:46

如何让你的Python代码更加pythonic ?的相关文章

Python代码样例列表

├─algorithm│       Python用户推荐系统曼哈顿算法实现.py│      NFA引擎,Python正则测试工具应用示例.py│      Python datetime计时程序的实现方法.py│      python du熊学斐波那契实现.py│      python lambda实现求素数的简短代码.py│      Python localtime()方法计算今天是一年中第几周.py│      Python math方法算24点代码详解.py│      Pyth

有用的Python代码片段

我列出的这些有用的Python代码片段,为我节省了大量的时间,并且我希望他们也能为你节省一些时间.大多数的这些片段出自寻找解决方案,查找博客和StackOverflow解决类似问题的答案.下面所有的代码片段已经在Python 3中测试. 在Python中调用一个外部命令 有时你需要通过shell或命令提示符调用一个外部命令,这在Python中通过使用subprocess模块很容易实现. 只需要运行一条命令: import subprocess subprocess.call(['mkdir',

这段代码很Pythonic | 相见恨晚的 itertools 库

前言 最近事情不是很多,想写一些技术文章分享给大家,同时也对自己一段时间来碎片化接受的知识进行一下梳理,所谓写清楚才能说清楚,说清楚才能想清楚,就是这个道理了. 很多人都致力于把Python代码写得更Pythonic,一来更符合规范且容易阅读,二来一般Pythonic的代码在执行上也更有效率.今天就先给大家介绍一下Python的系统库itertools. itertools库 迭代器(生成器)在Python中是一种很常用也很好用的数据结构,比起列表(list)来说,迭代器最大的优势就是延迟计算,

Effective Python之编写高质量Python代码的59个有效方法

                                                     这个周末断断续续的阅读完了<Effective Python之编写高质量Python代码的59个有效方法>,感觉还不错,具有很大的指导价值.下面将以最简单的方式记录这59条建议,并在大部分建议后面加上了说明和示例,文章篇幅大,请您提前备好瓜子和啤酒! 1. 用Pythonic方式思考 第一条:确认自己使用的Python版本 (1)有两个版本的python处于活跃状态,python2和pyt

PEP 8 -- Python代码格式规则

目录 PEP 8 -- Python代码格式规则 概述 教条主义是脑袋瓜中的小妖精 代码布局 缩进 制表符还是空格? 单行最大长度 该在二元运算符的前面还是后面换行 空行 源文件代码编写 导入 模块级双下名称 字符串的引号 表达式和语句中的空格 痛点 其他建议 何时使用收尾逗号 注释 块注释 行内注释 文档字符串 命名规范 最高原则 描述性:命名样式 约定俗成:名称传统 避免使用的名称 ASCII 兼容 包和模块名 类名 Type变量名 异常类名 全局变量名 函数和变量名 函数和方法的参数 方法

10 行 Python 代码实现模糊查询/智能提示

10 行 Python 代码实现模糊查询/智能提示 1.导语: 模糊匹配可以算是现代编辑器(如 Eclipse 等各种 IDE)的一个必备特性了,它所做的就是根据用户输入的部分内容,猜测用户想要的文件名,并提供一个推荐列表供用户选择. 样例如下: Vim (Ctrl-P) Sublime Text (Cmd-P) '模糊匹配'这是一个极为有用的特性,同时也非常易于实现. 2.问题分析: 我们有一堆字符串(文件名)集合,我们根据用户的输入不断进行过滤,用户的输入可能是字符串的一部分.我们就以下面的

200行Python代码实现2048

200行Python代码实现2048 一.实验说明 1. 环境登录 无需密码自动登录,系统用户名shiyanlou 2. 环境介绍 本实验环境采用带桌面的Ubuntu Linux环境,实验中会用到桌面上的程序: LX终端(LXTerminal): Linux命令行终端,打开后会进入Bash环境,可以使用Linux命令 GVim:非常好用的编辑器,最简单的用法可以参考课程Vim编辑器 3. 环境使用 使用GVim编辑器输入实验所需的代码及文件,使用LX终端(LXTerminal)运行所需命令进行操

解决Python代码编码问题 SyntaxError: Non-UTF-8 code starting with &#39;\xc1&#39;

导致出错的根源就是编码问题. 解决方案是: 在程序最上面加上: view plai# coding=gbk 这样程序就可以正常运行了. 解决Python代码编码问题 SyntaxError: Non-UTF-8 code starting with '\xc1'

python代码风格指南:pep8 中文翻译

摘要 本文给出主Python版本标准库的编码约定.CPython的C代码风格参见?PEP7.本文和?PEP 257 文档字符串标准改编自Guido最初的<Python Style Guide>, 并增加了Barry的?GNU Mailman Coding Style Guide的部分内容.本文会随着语言改变等而改变.许多项目都有自己的编码风格指南,冲突时自己的指南为准. 本文给出主Python版本标准库的编码约定.CPython的C代码风格参见PEP7. 本文和PEP 257 文档字符串标准改