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