【问题标题】:Cartesian product whose output is not in lexicographic ordering输出不按字典顺序排列的笛卡尔积
【发布时间】:2014-05-27 18:29:13
【问题描述】:

我想在 Python 中的可分割迭代之间做一个笛卡尔积,我想指定迭代的顺序。

例如我有 3 个可迭代对象:'AB', 'xy', '01' 在我的示例中。写的时候

import itertools
print list(itertools.product('AB', 'xy', '01')) 

输出在lexicographic order:

('A', 'x', '0')
('A', 'x', '1')
('A', 'y', '0')
('A', 'y', '1')
('B', 'x', '0')
('B', 'x', '1')
('B', 'y', '0')
('B', 'y', '1')

我希望能够指定我想首先迭代可迭代 1 ('AB'),然后迭代可迭代 3 ('01'),然后可迭代 2 ('xy'),这将给出以下输出:

('A', 'x', '0')
('B', 'x', '0')
('A', 'x', '1')
('B', 'x', '1')
('A', 'y', '0')
('B', 'y', '0')
('A', 'y', '1')
('B', 'y', '1')

在 Python 中是否有任何标准方法可以做到这一点?我可以使用 Numpy。

【问题讨论】:

  • 你为什么不按照你想要迭代的顺序传递迭代器?
  • @BrenBarn 每个元组的元素必须以某种方式排序。我想我可以在调用 itertools.product 后重新组织它们,但这听起来像是不必要的第二遍。

标签: python


【解决方案1】:

只需按照您希望它们被迭代的顺序传递可迭代对象(或者更确切地说,使用您的术语,相反的顺序 --- 第一个传递的将是最外层的迭代,因此它将循环“最慢”)。如果您必须以不同的顺序获得结果元组,只需在之后交换结果即可:

>>> [(c, a, b) for a, b, c in itertools.product('xy', '01', 'AB')]
[(u'A', u'x', u'0'),
 (u'B', u'x', u'0'),
 (u'A', u'x', u'1'),
 (u'B', u'x', u'1'),
 (u'A', u'y', u'0'),
 (u'B', u'y', u'0'),
 (u'A', u'y', u'1'),
 (u'B', u'y', u'1')]

请注意,这不需要对结果进行任何额外的传递:每个元组在生成时都会被交换。

【讨论】:

  • 谢谢,我没想到交换会这么容易!
猜你喜欢
  • 2019-07-23
  • 2011-07-10
  • 2017-10-16
  • 1970-01-01
  • 2012-08-17
  • 2018-11-09
  • 1970-01-01
  • 2012-05-18
  • 2023-03-17
相关资源
最近更新 更多