
一直很纠结对一些很长的列表表达式该如何改写使其满足 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 |
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 日 拆 |