最好的信息来源是关于列表推导的官方 Python 教程。列表推导与 for 循环几乎相同(当然,任何列表推导都可以写成 for 循环),但它们通常比使用 for 循环更快。
从教程中查看这个更长的列表推导(该if
部分过滤推导,只有通过 if 语句的部分才被传递到列表推导的最后部分(此处(x,y)
):
>>> [(x, y) for x in [1,2,3] for y in [3,1,4] if x != y]
[(1, 3), (1, 4), (2, 3), (2, 1), (2, 4), (3, 1), (3, 4)]
它与这个嵌套的 for 循环完全相同(并且,正如教程所说,请注意 for 和 if 的顺序如何相同)。
>>> combs = []
>>> for x in [1,2,3]:
... for y in [3,1,4]:
... if x != y:
... combs.append((x, y))
...
>>> combs
[(1, 3), (1, 4), (2, 3), (2, 1), (2, 4), (3, 1), (3, 4)]
列表推导式和 for 循环之间的主要区别在于 for 循环的最后部分(你在其中做某事的地方)出现在开头而不是结尾。
关于你的问题:
对象必须是什么类型才能使用这个 for 循环结构?
一个可迭代的. 可以生成(有限)一组元素的任何对象。这些包括任何容器、列表、集合、生成器等。
将 i 和 j 分配给 object 中的元素的顺序是什么?
它们的分配顺序与从每个列表生成的顺序完全相同,就好像它们在嵌套的 for 循环中一样(对于您的第一个理解,您将获得 i 的 1 个元素,然后从 j 中获得每个值,将第二个元素放入 i,然后来自 j 的每个值等)
可以用不同的for循环结构来模拟吗?
是的,上面已经显示了。
这个 for 循环可以嵌套在类似或不同结构的 for 循环中吗?它看起来如何?
当然可以,但这不是一个好主意。例如,这里给你一个字符列表:
[[ch for ch in word] for word in ("apple", "banana", "pear", "the", "hello")]