我有一张这样的清单:
['lion', '23', '35']
['lion', '24', '68']
['elephant', '23', '34']
['monkey', '4', '20']
['monkey', '5', '25']
['monkey','28', '90']
['lion', '33', '2']我想对它们进行分类,并将具有连续值(23-34)的同类动物合并起来,并将其相邻的值合并(例如,35-68的狮子值),如下所示:
['lion', '23-24', '35-68']
['lion', '33', '2']
['elephant', '23', '34']
['monkey', '4-5', '20-25']
['monkey', '28', '90']注意,狮子和猴子的连续值是用破折号和它旁边的序列合并和分开的。不是连续的:狮子33只,猴子28只。
我尝试了一些迭代工具和groupby以及labda排序的代码,但都没有效果。
例如
strings.sort(key=lambda元素:(element,element1))
用动物的名字和连续的数字对它们进行排序,但我不知道如何合并它们。
我想要的是按照动物的名字按字母顺序排序,并将那些具有连续秒值的动物合并起来,然后用这个输出创建一个新的列表。
有什么想法吗?
发布于 2018-01-26 05:25:15
您可以尝试这样的方法,并从下面的代码中获得提示:
data=[['lion', '23', '35'],
['lion', '24', '68'],
['elephant', '23', '34'],
['monkey', '4', '20'],
['monkey', '5' , '25'],
['monkey','28', '90'],
['lion', '33', '2']]
from itertools import groupby
from itertools import combinations
final_=[]
for i,j in groupby(sorted(data),key=lambda x:x[0]):
final_.append(list(j))
final__=[]
check=[]
for mn in final_:
if len(mn)==1:
final__.append(mn)
for k in combinations(mn,r=2):
if abs(int(k[0][1])-int(k[1][1]))==1:
check.extend(k)
final__.append([k[0][0],"{}-{}".format(k[0][1],k[1][1]),"{}-{}".format(k[0][2],k[1][2])])
else:
if k[0] not in check:
if k[0] not in final__:
final__.append(k[0])
elif k[1] not in check:
if k[1] not in final__:
final__.append(k[1])
print(final__)产出:
[[['elephant', '23', '34']], ['lion', '23-24', '35-68'], ['lion', '33', '2'], ['monkey', '28', '90'], ['monkey', '4-5', '20-25']]https://stackoverflow.com/questions/48445050
复制相似问题