Python 辞書を持っている場合、最小値を含むエントリへのキーを取得するにはどうすればよいですか?
機能をどうにかしようと考えていたのですがmin()
…
入力が与えられた場合:
{320:1, 321:0, 322:3}
返され321
ます。
Python 辞書を持っている場合、最小値を含むエントリへのキーを取得するにはどうすればよいですか?
機能をどうにかしようと考えていたのですがmin()
…
入力が与えられた場合:
{320:1, 321:0, 322:3}
返され321
ます。
ベスト: min(d, key=d.get)
-- 役に立たないlambda
間接レイヤーを挿入したり、アイテムやキーを抽出したりする理由はありません!
>>> d = {320: 1, 321: 0, 322: 3}
>>> min(d, key=d.get)
321
OPが求めた解決策を実際に提供する答えは次のとおりです。
>>> d = {320:1, 321:0, 322:3}
>>> d.items()
[(320, 1), (321, 0), (322, 3)]
>>> # find the minimum by comparing the second element of each tuple
>>> min(d.items(), key=lambda x: x[1])
(321, 0)
ただし、より大きな辞書の場合は、を使用d.iteritems()
する方が効率的です。
min(d.items(), key=lambda x: x[1])[0]
最小限のキーが複数あり、シンプルに保ちたい場合
def minimums(some_dict):
positions = [] # output variable
min_value = float("inf")
for k, v in some_dict.items():
if v == min_value:
positions.append(k)
if v < min_value:
min_value = v
positions = [] # output variable
positions.append(k)
return positions
minimums({'a':1, 'b':2, 'c':-1, 'd':0, 'e':-1})
['e', 'c']
>>> d = {320:1, 321:0, 322:3}
>>> min(d, key=lambda k: d[k])
321
複数の最小値がないかどうかわからない場合は、次のことをお勧めします。
d = {320:1, 321:0, 322:3, 323:0}
print ', '.join(str(key) for min_value in (min(d.values()),) for key in d if d[key]==min_value)
"""Output:
321, 323
"""
keys
関数を使用してdictのキーを取得できますmin
。そのリストの最小値を見つけるために使用するのは正しいです。
これは、最小限の答えではなく、最小限のキーに関するOPの元の質問に対する答えです。
同じ最小値を持つ複数のキーの問題に対処する別のアプローチ:
>>> dd = {320:1, 321:0, 322:3, 323:0}
>>>
>>> from itertools import groupby
>>> from operator import itemgetter
>>>
>>> print [v for k,v in groupby(sorted((v,k) for k,v in dd.iteritems()), key=itemgetter(0)).next()[1]]
[321, 323]
d={}
d[320]=1
d[321]=0
d[322]=3
value = min(d.values())
for k in d.keys():
if d[k] == value:
print k,d[k]
注文可能なクラスを作成するには、min() 関数によって呼び出されるように、6 つの特別な関数をオーバーライドする必要があります。
これらのメソッドは__lt__ , __le__, __gt__, __ge__, __eq__ , __ne__
、より小さい、より小さいか等しい、より大きい、より大きいか等しい、等しい、等しくないという順序になっています。
たとえば、__lt__
次のように実装する必要があります。
def __lt__(self, other):
return self.comparable_value < other.comparable_value
次に、次のように min 関数を使用できます。
minValue = min(yourList, key=(lambda k: yourList[k]))
これは私にとってはうまくいきました。
# python
d={320:1, 321:0, 322:3}
reduce(lambda x,y: x if d[x]<=d[y] else y, d.iterkeys())
321