内联for循环 [英] Inline for loop

查看:24
本文介绍了内联for循环的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在努力学习简洁的蟒蛇式的做事方式,我想知道为什么我的for循环不能以这种方式重构:

q  = [1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5]
vm = [-1, -1, -1, -1]

for v in vm:
    if v in q:
        p.append(q.index(v))
    else:
        p.append(99999)

vm[p.index(max(p))] = i

我尝试将for循环替换为:

[p.append(q.index(v)) if v in q else p.append(99999) for v in vm]

但是它不起作用。for v in vm:循环根据数字在q中的下一个出现时间逐出vm中的数字。

Python

您正在使用的在推荐答案中称为list comprehension,而不是内联for循环(尽管它与一个循环相似)。您可以将循环编写为列表理解形式,如下所示:

p = [q.index(v) if v in q else 99999 for v in vm]

在使用列表理解时,您不会调用list.append,因为列表是从理解本身构造的。列表中的每一项都将是for关键字左侧的表达式返回的内容,在本例中为q.index(v) if v in q else 99999。顺便说一句,如果您确实在理解中使用了list.append,那么您将获得一个None值的列表,因为这是append方法总是返回的。

这篇关于内联for循环的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆