如果我有一个列表:
[[ 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
答案 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]]