拆开列表Python

时间:2015-10-01 14:26:22

标签: python list stacked

如果我有一个列表:

[[ 2, 3, 4.0, 1], [3], [ 2, 1, 5, 2, 6], [ 2.2, 1]]. 

如何在python中编写获取此列表的代码并查找连续正数的数量,然后创建一个列表,其中包含每个连续数字的列表。

例如x的这个例子将返回一个数字4 它也会回来:

 zeros = []
 for i in range(0,len(World)):
      if z[i]==0: 
          zeros.append(i)

我写这篇文章是为了找到所有零,但我不知道从哪里去:

yo meanjs

2 个答案:

答案 0 :(得分:7)

没有必要罚款零。您可以简单地循环遍历列表并将正数放在临时列表中,直到遇到零,但作为此类任务的更加pythonic方法,您可以使用itertools.groupby

>>> from itertools import groupby
>>> [list(g) for k,g in groupby(X,key=lambda x:x>0) if k]
[[2, 3, 4.0, 1], [3], [2, 1, 5, 2, 6], [2.2, 1]]

如果你想在没有itertools模块的情况下这样做,你可以使用以下功能,该功能根据前面的解释工作,并在每次遇到零时产生临时列表,最后返回一个包含正数列表的生成器您可以通过调用list函数将其转换为列表:

>>> def grouper(li,temp=[]):
...    for i in li:
...        if i>0:
...           temp.append(i)
...        else:
...            if temp: yield temp
...            temp=[]
...    if temp : yield temp
...

演示:

>>> list(grouper(X))
[[2, 3, 4.0, 1], [3], [2, 1, 5, 2, 6], [2.2, 1]]

答案 1 :(得分:2)

您不需要事先找出零的索引。您可以简单地保留另一个临时列表,其中包含自上次遇到0以来的正值(大于0)。然后,当您遇到0时,将该临时列表附加到结果列表,并将该临时列表更改为新列表。示例 -

result = []
temp = []
for i in X:
    if i <= 0:
        if temp:
            result.append(temp)
            temp = []
    else:
        temp.append(i)
if temp:
    result.append(temp)

演示 -

>>> result = []
>>> temp = []
>>> for i in X:
...     if i <= 0:
...         if temp:
...             result.append(temp)
...             temp = []
...     else:
...         temp.append(i)
...
>>> if temp:
...     result.append(temp)
...
>>> result
[[2, 3, 4.0, 1], [3], [2, 1, 5, 2, 6], [2.2, 1]]