python – PEP 8和列表理解

我似乎对PEP 8遇到了一些问题.

我正在使用长度超过79个字符的列表理解.因此,我的文本编辑器正在尖叫着对我做些什么,并且在编码时要注意一下.

return [(i['user_id'],i['id']) for i in j['collection'] if i and i['user_id']]

所以,我试图打破界限,但现在它抱怨我的换行是出于视觉目的.

return [(i['user_id'],i['id']) for i in j['collection']
    if i and i['user_id']]

在这样的泡菜中,男人该做什么?

编辑:基于答案,在这种情况下我选择了列表理解的可读性,现在它对读者更有意义:

tracks = set()

for track in json['collection']:
    if track and track['user_id']:
        tracks.add((track['user_id'],track['id']))

解决方法

使用pep8时常识适用.如果你不能在80字符内拟合一行逻辑,那么几乎总是表明这条线必须被重写.在这种情况下确实如此,因为我甚至无法开始尝试理解那条线应该做什么.

但是如果你将它移动到一个更易读的格式,那么不仅你的行数会增加,而且你的可读性水平也会提高,这样就可以为你提供很多适当的变量名称,比如用户而不是i.这将使您在未来的维护变得更加容易,更不用说其他人是否需要查看它.

所以把这个例子放到实际的代码中,这就是我用它做的事情(使用一个很好的函数换行来使样本更容易阅读!):

j = {'collection': [{'id': 1,'user_id': 1}]}

def get_qualified_users(users):
    qualified_users = []
    for user in users:
        if user and user['user_id']:
            qualified_users.append((user['user_id'],user['id']))
    return qualified_users

print(get_qualified_users(j['collection']))

您可以轻松地将其复制/粘贴到您的interpetor中,看它是否有效.更重要的是 – 它非常容易维护和跟踪,在密封功能中封装了清晰的api.

相关文章

在这篇文章中,我们深入学习了XPath作为一种常见的网络爬虫技巧。XPath是一种用于定位和选择XML文档中特...
祝福大家龙年快乐!愿你们的生活像龙一样充满力量和勇气,愿你们在新的一年里,追逐梦想,勇往直前,不...
今天在爬虫实战中,除了正常爬取网页数据外,我们还添加了一个下载功能,主要任务是爬取小说并将其下载...
完美收官,本文是爬虫实战的最后一章了,所以尽管本文着重呈现爬虫实战,但其中有一大部分内容专注于数...
JSON是一种流行的数据传输格式,Python中有多种处理JSON的方式。官方的json库是最常用的,它提供了简单...
独立样本T检验适用于比较两组独立样本的均值差异,而配对T检验则适用于比较同一组样本在不同条件下的均...