一直很纠结对一些很长的列表表达式该如何改写使其满足 PEP8 的规范……比如如下代码:
left_correct = sum([1 for ins in instances if self.is_acc(ins.left_label, ins.left_score)])
直接拦腰砍断么……感觉很丑啊……
1
billlee 2016 年 1 月 29 日
a_list = [a_long_expression(item)
for item in another_list if another_expression(item)] |
3
cxbig 2016 年 1 月 29 日
- 拆成多行, assign 给多个变量
- 用 alias 缩短长 fn/method |
4
xuboying 2016 年 1 月 29 日 via Android
这种代码可读性好差
|
5
ipconfiger 2016 年 1 月 29 日
变量名起得长很容易就超标了.......
|
6
raquelken 2016 年 1 月 29 日
拆吧
bigger_than_1 = lambda num: num > 1 amount = len(filter(bigger_than_1, [1, 2, 3])) |
7
Delbert 2016 年 1 月 29 日
@billlee 不应该是
a_list = [a_long_expression(item) \ for item in another_list \ if another_expression(item)] 么? |
9
fy 2016 年 1 月 30 日
抓大放小,这种小细节就不必在意了,核心是可读性
|
10
gkiwi 2016 年 1 月 30 日
觉的楼主的问题应该是,我写了不符合 pep8 规范的代码, pep8 检查器老报异常很烦人怎么办。。。
这样子在需要的行后面加上 # noqa 有图为证: |
11
gkiwi 2016 年 1 月 30 日
呃呃呃,图丢了,楼主自己 search 下 pep8 noqa 就晓得了~~
|
12
gkiwi 2016 年 1 月 30 日
不过话说回来,对于特别长的表达式,还是换行是一种好的策略,毕竟代码是写给别人看的,阅读方便才是首要任务
|
13
leavic 2016 年 1 月 31 日
you really need pycharm
|
14
zjq426 2016 年 1 月 31 日
拆行+1
|
15
pynix 2016 年 2 月 1 日
拆
|