编写高质量代码 改善Python程序的91个建议 (读后 小记)(编写高质量代码应遵循的规则有哪些?)

网友投稿 266 2022-09-03


编写高质量代码 改善Python程序的91个建议 (读后 小记)(编写高质量代码应遵循的规则有哪些?)

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

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

#!/usr/bin/env python#encoding:UTF-8def 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' breakFinallyTest()

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

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

建议 37:

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

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

1. 对字典排序

from operator import itemgetterphonebook = {"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 itemgettergameresult = [['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 itemgettermydict = {'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 defaultdictsome_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]+=1print count_frq

输出:

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

pythonic 方法:

使用  Counter

from collections import Countersome_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)]


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:递归遍历嵌套结构(多层List)中的元素 ------Python(层次遍历非递归)
下一篇:Java使用selenium爬取b站动态的实现方式
相关文章

 发表评论

暂时没有评论,来抢沙发吧~