私は基本的に、dictを反復処理して、キー/値を最大値から最小値まで出力しようとしています。私はこのサイトを検索していて、多くの人がラムダを使用していますが、どのように機能するのか本当にわからないので、今は避けたいと思っています。
dictIterator = iter(sorted(bigramDict.iteritems()))
for ngram, value in dictIterator:
print("There are " + str(value) + " " + ngram)
上記のコードを確認すると、キーと値のペアを最大から最小の順に返すイテレータが作成されると思いましたが、そうではありません。
誰が問題が何であるかを見ることができますか?またはこれを行う別の方法?
最初の要素を2番目の要素よりも重要であると考えることで、タプルでソートが機能するという事実を利用できます。
d = { "a":4, "c":3, "b":12 }
d_view = [ (v,k) for k,v in d.iteritems() ]
d_view.sort(reverse=True) # natively sort tuples by first element
for v,k in d_view:
print "%s: %d" % (k,v)
出力:
b: 12
a: 4
c: 3
編集:ワンライナー、ジェネレーター式:
sorted( ((v,k) for k,v in d.iteritems()), reverse=True)
出力:
[(12, 'b'), (4, 'a'), (3, 'c')]
key
のsorted
パラメータを使用して、2番目のアイテムで並べ替えることができます。
>>> d = { "a":4, "c":3, "b":12 }
>>> from operator import itemgetter
>>> for k, v in sorted(d.items(), key=itemgetter(1)):
print k, v
c 3
a 4
b 12
>>>
編集:ワンライナー、逆順:
>>> d = {"a": 4, "c": 3, "b": 12}
>>> [(k, v) for k, v in sorted(d.items(), key=lambda x: x[1], reverse=True)]
[('b', 12), ('a', 4), ('c', 3)]
>>>
>>> d = { "a":4, "c":3, "b":12 }
>>> from operator import itemgetter
>>> lst = sorted(d.iteritems(), key=itemgetter(1))
>>> for t in lst: print '%s : %d' % (t[0], t[1])
...
c : 3
a : 4
b : 12
d = { "a":4, "c":3, "b":12 }
for v in sorted( d.values() ):
for key in d:
if d[ key ] == v:
print key, v
break