编写高质量代码 改善Python程序的91个建议    (读后 小记)_Python


此书是自己好久之前买的,当时总觉得Python语言中有各种trick, 总是要自己猝不及防的掉入到陷阱之中, 看了一些资料后发现了这本书,感觉很是不错,不过可惜自己平时总是杂事太多,总是找不到整块的时间把这本书看完。现在正好赶上自己放寒假,这也是到了新单位后的第一个假期,BOSS说工作学习要靠自己自觉,不过不管怎么说我总是属于不太自觉的那个类型的,于是开启了小差,这也顺路把这本压箱底的书翻了出来,以下记录一些自己觉得自己平时没有注意到的小问题,有选择的记录到下面,也算是读书的小笔记,供自己日后翻查所用。

建议25:  避免finally中可能发生的陷阱

#!/usr/bin/env python
#encoding:UTF-8

def FinallyTest():
print 'I am starting------'
while True:
try:
print "I am running"
raise IndexError("r")
except NameError, e:
print 'NameError happened%s', e
break
finally:
print 'finally executed'
break

FinallyTest()

编写高质量代码 改善Python程序的91个建议    (读后 小记)_Python_02


try 块中发生异常的时候,如果在except语句中找不到对应的异常,异常将会被临时保存起来,在finally语句结束时再去执行刚才保存的内容,即保存的异常,如果此时finally中有break或者return 则会覆盖掉保存的内容,起到屏蔽异常的作用。


所以,在finally之中尽量不要使用break语句或return语句,以防止在程序出现问题时导致调试困难。


建议 37:

对字典排序, 利用    {}.iteritems   ,   key=itemgetter

对个操作个人感觉比较受用,因为以前曾经编写过NSGA-II 的Python程序, 其中有很大一部分需要用到对字典的排序,当时实现的十分蹩脚,看到这个应用感觉一亮。

1. 对字典排序

from operator import itemgetter

phonebook = {"Linda":'7750', "Bob":'9345', 'Carol':'5834'}

sorted_pb = sorted(phonebook.iteritems(), key=itemgetter(1))

print sorted_pb


输出:

[('Carol', '5834'), ('Linda', '7750'), ('Bob', '9345')]


2. 多维list排序

在sorted中 key 和 cmp 都是接收函数的参数, 但是cmp中的函数需要对两两传入的元素进行大小判断, 而key函数只需要返回一个用来判断两两元素大小的一个判断元素即可。

from operator import itemgetter

gameresult = [['Bob', 95.00, 'A'], ['Alan', 86.00, 'C'], ['Mandy', 82.50, 'A'], ['Rob', 86, 'E']]

sorted_gameresult=sorted(gameresult, key=itemgetter(2, 1) )

print sorted_gameresult

输出:

[['Mandy', 82.5, 'A'], ['Bob', 95.0, 'A'], ['Alan', 86.0, 'C'], ['Rob', 86, 'E']]

字典中混合 List 排序, 该种排序我认为是比较常见的一种,同时也是非常不好处理的一种:

from operator import itemgetter

mydict = {'Li':['M', 7], 'Zhang':['E', 2], 'Wang':['P', 3], 'Du':['C', 2], 'Ma':['C', 9], 'Zhe':['H', 7]}

sorted_mydict=sorted(mydict.iteritems(), key=lambda (k, v): itemgetter(1)(v) )

print sorted_mydict

输出:

[('Zhang', ['E', 2]), ('Du', ['C', 2]), ('Wang', ['P', 3]), ('Li', ['M', 7]), ('Zhe', ['H', 7]), ('Ma', ['C', 9])]

建议39:

使用Counter进行计数统计

from collections import defaultdict
some_data=[1,2,1,2,1,2,2,2,3,1,1,3,1,2,2,1,1,4]
count_frq=defaultdict(int)
for item in some_data:
count_frq[item]+=1
print count_frq

输出:

defaultdict(<type 'int'>, {1: 8, 2: 7, 3: 2, 4: 1})

pythonic 方法:

使用  Counter

from collections import Counter
some_data=[1,2,1,2,1,2,2,2,3,1,1,3,1,2,2,1,1,4]
count_frq=Counter(some_data)
print count_frq

输出:

Counter({1: 8, 2: 7, 3: 2, 4: 1})


Counter 类是属于字典的一个子类型。

Counter初始化:

Counter('success')

Counter(s=3, c=2, u=1)

Counter({'s'=3, 'c'=2, 'u'=1})


list(Counter({'s': 3, 'c': 2, 'e': 1, 'u': 1}).elements())

['e', 's', 's', 's', 'u', 'c', 'c']


>>> Counter({'s': 3, 'c': 2, 'e': 1, 'u': 1}).values()

[1, 3, 1, 2]


>>> w

Counter({'s': 3, 'c': 2, 'e': 1, 'u': 1})

>>> w.update({'s':7})



>>> Counter({'s': 3, 'c': 2, 'e': 1, 'u': 1}).most_common(4)

[('s', 3), ('c', 2), ('e', 1), ('u', 1)]