0

我想展平列表:

exampleArray = [[[151.68694121866872]], 
                [[101.59534468349297]], 
                [[72.16055999176308]]]

到:

[151.68694121866872, 101.59534468349297, 72.16055999176308]

现在我正在这样做:

resultArray= list(chain.from_iterable(list(chain.from_iterable(exampleArray))))

即使它有效,我也想知道是否有更好的方法。

4

5 回答 5

2

怎么样

result = [x[0][0] for x in exampleArray]
于 2012-10-15T09:51:03.013 回答
1
In [6]: from itertools import chain

In [7]: lis=[[[151.68694121866872]], [[101.59534468349297]], [[72.16055999176308]]]

In [8]: list(chain(*(chain(*lis))))

Out[8]: [151.68694121866872, 101.59534468349297, 72.16055999176308]
于 2012-10-15T09:52:03.183 回答
1

没有更好的方法,这是最推荐的方法。见官方食谱

def flatten(listOfLists):
    "Flatten one level of nesting"
    return chain.from_iterable(listOfLists)
于 2012-10-15T09:52:24.703 回答
1

您不需要将itertools.chain对象(可迭代)转换为列表:

resultArray= list(chain.from_iterable(list(chain.from_iterable(exampleArray))))
# could be rewritten as
resultArray= list(chain.from_iterable(chain.from_iterable(exampleArray)))

.

您可以使用递归编写深度函数:

def deep_chain_from_iterable(it, n):
    if n == 0:
        return list(it)
    else:
        return deep_chain_from_iterable(itertools.chain.from_iterable(it),n-1)

deep_chain_from_iterable(exampleArray, 2)
于 2012-10-15T09:59:41.607 回答
0

对于固定的深度级别(如示例),您可以将足够的时间相加:

sum(sum(listoflistsoflists, []), [])
于 2012-10-15T11:56:04.357 回答