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