0

我意识到这是一个基本问题,但我无法让它发挥作用。我有以下元组:

t = (('apple', 'banana'), ('apple', 'carrot'), ('banana', 'carrot'))

我希望每个元组中的第一项t是唯一的,并将每个重复项的第二项合并到一个字典中。

t = {('apple': 'banana', 'carrot'), ('banana': 'carrot')}

毫不奇怪,这不起作用:

t = dict(zip(set(t[0]),t[1]))

这是结果:

{'apple': 'apple', 'banana': 'carrot'}
4

3 回答 3

3

我认为,您应该在dict这里使用 a (或者更确切地说是 a defaultdict)。其中keydict将是你的内部元组的第一个元素 - tup[0]

这就是你想要的:

>>> t = (('apple', 'banana'), ('apple', 'carrot'), ('banana', 'carrot'))
>>>
>>> from collections import defaultdict
>>> 
>>> temp_dict = defaultdict(tuple)
>>> 
>>> for tup in t:
        temp_dict[tup[0]] += tup[1:]  


>>> temp_dict
defaultdict(<type 'tuple'>, {'apple': ('banana', 'carrot'), 'banana': ('carrot',)})

>>> {key:value for key, value in temp_dict.items()}
{'apple': ('banana', 'carrot'), 'banana': ('carrot',)}
于 2013-02-16T22:10:10.920 回答
1

这是一个完整的解决方案(编辑:现在 兼容 Python 3):

import functools
t = (('apple', 'banana'), ('apple', 'carrot'), ('banana', 'carrot'))

def insert(d,k,v):
        d[k] = (v,) if k not in d else d[k]+(v,)
        return d

z = functools.reduce(lambda d,ti: insert(d,*ti),t,{})

def flat(tpl):
        return sum([(x,) if not isinstance(x,tuple) else x for x in tpl],())

result = [flat(x) for x in z.items()]

产量:

[('apple', 'banana', 'carrot'), ('banana', 'carrot')]

于 2013-02-16T22:20:30.557 回答
1

对于这样的情况,dicts的setdefault方法会派上用场:

t = (('apple', 'banana'), ('apple', 'carrot'), ('banana', 'carrot'))
d = {}
[d.setdefault(k,[]).append(v) for k,v in t]
于 2013-02-16T22:36:16.303 回答