2 回答
TA贡献1866条经验 获得超5个赞
您可以使用 itertools.groupby 按第二个元素进行分组,然后提取每个组的第一个元素:
from itertools import groupby
from operator import itemgetter
data = [('I', 'N'), ('love', 'V'), ('Miley', 'N'), ('Cyrus', 'N'), ('but', 'ADV'), ('hate', 'V'), ('Liam', 'N'),
('Hemsworth', 'N')]
result = [' '.join(t[0] for t in group) for k, group in groupby(data, key=itemgetter(1))]
print(result)
输出
['I', 'love', 'Miley Cyrus', 'but', 'hate', 'Liam Hemsworth']
上面的列表理解等效于以下 for 循环:
result = []
for k, group in groupby(data, key=itemgetter(1)):
result.append(' '.join(t[0] for t in group))
TA贡献1802条经验 获得超10个赞
用itertools.groupby
前任:
from itertools import groupby
data = [('I', 'N'),('love', 'V'),('Miley', 'N'),('Cyrus', 'N'),('but', 'ADV'),('hate', 'V'),('Liam', 'N'),('Hemsworth', 'N')]
result = [" ".join(m for m, _ in v) for k, v in groupby(data, lambda x: x[1])]
print(result)
输出:
['I', 'love', 'Miley Cyrus', 'but', 'hate', 'Liam Hemsworth']
添加回答
举报
