当前位置:  开发笔记 > 编程语言 > 正文

在Python中,是否有一种使用多个迭代器的列表理解的简明方法?

如何解决《在Python中,是否有一种使用多个迭代器的列表理解的简明方法?》经验,为你挑选了3个好方法。

基本上,我想建立一个列表理解两个迭代器的"笛卡尔积".想想以下Haskell代码:

[(i,j) | i <- [1,2], j <- [1..4]]

产量

[(1,1),(1,2),(1,3),(1,4),(2,1),(2,2),(2,3),(2,4)]

我能以简洁的方式在Python中获得类似的行为吗?



1> S.Lott..:

你在问这个吗?

[ (i,j) for i in range(1,3) for j in range(1,5) ]



2> A. Coady..:

笛卡尔积在itertools模块中(在2.6中).

>>> import itertools
>>> list(itertools.product(range(1, 3), range(1, 5)))
[(1, 1), (1, 2), (1, 3), (1, 4), (2, 1), (2, 2), (2, 3), (2, 4)]



3> Rafał Dowgir..:

关于嵌套理解的有趣事实:它模仿嵌套的"for"循环,因此内部的可以使用外部的值.这在笛卡儿产品案例中没用,但很有用.例如:

[ (i,j) for i in range(10) for j in range(i) ] 

产生所有对(i,j)其中0>=i>j>10.

推荐阅读
殉情放开那只小兔子
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有