2

我有一个元组,它由一些整数元组和一些整数组成,比如((1, 2), 3, (4, 5), 6)。现在我需要它的所有整数。我写:

def get_all_items(iterable):
    t = []

    for each in iterable:
        if type(each) == int:
            t.append(each)
        else:
            t.extend(each)

    return tuple(t)

这个对我有用。有没有更好的方法来做到这一点?

4

5 回答 5

3

不要忘记作弊方式

>>> from ast import literal_eval
>>> t = ((1, 2), 3, (4, 5), 6)
>>> literal_eval(repr(t).translate(None, '()'))
(1, 2, 3, 4, 5, 6)
于 2013-10-15T04:05:50.873 回答
1
from itertools import chain

def flatten(items):
  def renest():
    for item in items:
      try:
        yield iter(item)
      except TypeError:
        yield iter([item])
  return list(chain.from_iterable(renest()))
于 2013-10-15T03:12:04.563 回答
1

您可以像这样简化代码

def get_all_items(iterable):
    t = []
    for each in iterable:
        t.extend(list(each) if isinstance(each, tuple) else [each])
    return tuple(t)

print get_all_items(((1, 2), 3, (4, 5), 6))

输出

(1, 2, 3, 4, 5, 6)
于 2013-10-15T03:49:09.707 回答
1
import itertools
itertools.chain.from_iterable(
    item if hasattr(item, '__iter__') else (item,)
        for item in iterable 
)
于 2013-10-15T03:40:50.100 回答
1

我觉得你的方法很好。这是另一种使用递归的方法,它适用于任意深度嵌套的可迭代结构:

def get_all_items(iterable):
    try:
        result = []
        for element in iterable:
            result += detuple(element)
        return result
    except TypeError:
        return [iterable]

此外,了解您所描述的操作称为“扁平化”数据结构可能很有用。

于 2013-10-15T03:19:05.323 回答