4

次のように、キーとしてタプルを持つ辞書があります。

d={('w1','u1'):3,('w1','u2'):8,('w2','u1'):1,('w1','u3'):11,('w2','u3'):6}

ここで、各「w」、つまりキーの最初の要素のすべてのアイテムを収集したいと思います。

'w1' :  ('w1','u1'):3 ('w1','u2'):8 ('w1','u3'):11 -------
'w2' :  ('w2','u1'):1 ('w2','u3'):6 

次に、取得する値で各行を並べ替えます。

'w1' : 'u3':11 'u2':8 'u1':3 -------
'w2' :  'u3':6 'u1':1

誰かがそれを行うためのヒントを教えてもらえますか? ありがとう

4

2 に答える 2

3

これにより、必要なものがソートされます。しかし、辞書を並べ替えることができないため、最後に辞書にはありません。

d={('w1','u1'):3,('w1','u2'):8,('w2','u1'):1,('w1','u3'):11,('w2','u3'):6}

d2 = {}

for (w,u) , value in d.items():
    if w not in d2:
        d2[w] = [(u,value)]
    else:
        d2[w].append((u, value))


for key, values in d2.items():
    print key, ":\t", sorted(values, key=lambda x: -x[1]), "\n"

与える:

w2 :    [('u3', 6), ('u1', 1)] 

w1 :    [('u3', 11), ('u2', 8), ('u1', 3)] 
于 2013-07-13T13:06:50.670 に答える
2

あなたが求めているファイナルを考えると、dictソートする必要はないように思えます。キーと値のペアを繰り返し処理し、それらを新しい dict に再配置します。

d = {('w1', 'u1'): 3, ('w1', 'u2'): 8, ('w2', 'u1'): 1, ('w1', 'u3'): 11,
     ('w2', 'u3'): 6}
result = {}
for (w, u), val in d.iteritems():
    result.setdefault(w, {})[u] = val
print(result)

収量

{'w2': {'u1': 1, 'u3': 6}, 'w1': {'u1': 3, 'u3': 11, 'u2': 8}}
于 2013-07-13T12:58:44.450 に答える