【问题标题】:Using itertools to group consecutive tuples by second value使用 itertools 按第二个值对连续元组进行分组
【发布时间】:2014-03-16 23:51:12
【问题描述】:

我在表格中有一组数据:

X1 = [(1,1),(3,1),(5,0),(3,0),(2,1)]

我不知道如何将它们分组:

X2 = [[(1,1),(3,1)],[(5,0),(3,0)],[(2,1)]]

即它们按每个元组中的第二个值连续分组。

我知道是这样的:

http://docs.python.org/2/library/itertools.html#itertools.groupby

【问题讨论】:

  • 既然有更简单的方法,为什么还要使用 itertools?
  • @Ol'Reliable:因为你的“更简单的方法”做了一些不同的事情。如果数据是[(0, 1), (1, 1), (2, 1), (0, 0), (0, 2)]怎么办?
  • 输出应该是什么?
  • [[(0, 1), (1, 1), (2, 1)], [(0, 0)], [(0, 2)]]
  • 好吧好吧,对不起,我没有完全理解这个问题

标签: python tuples itertools


【解决方案1】:
from itertools import groupby
from operator import itemgetter
X2 = [list(group) for key, group in groupby(X1, itemgetter(1))]

key 函数传递给groupby,该函数获取每个元组的第二项,因此groupby 按第二项对元组进行分组。

【讨论】:

  • ...喜欢这种灵活性,所以我会选择这个。打得好!
【解决方案2】:
from itertools import groupby, imap
from operator  import itemgetter

X1 = [(1,1),(3,1),(5,0),(3,0),(2,1)]
print map(list, imap(itemgetter(1), groupby(X1, itemgetter(1))))
# -> [[(1, 1), (3, 1)], [(5, 0), (3, 0)], [(2, 1)]]

【讨论】:

    【解决方案3】:
    x = [(1,1),(3,1),(5,0),(3,0),(2,1)]
    y = [x[n:n+2] for n in range(0, len(x), 2)]
    print(y)
    

    【讨论】:

    • 功能齐全,无需模块,流畅!
    猜你喜欢
    • 1970-01-01
    • 2019-11-25
    • 1970-01-01
    • 2015-06-16
    • 2011-10-25
    • 1970-01-01
    • 2022-01-28
    • 1970-01-01
    相关资源
    最近更新 更多