簡體   English   中英

如何在具有混合類型值的字典中獲取具有最大日期值的項目?

[英]How to get the item with max date value in a dictionary with mixed type values?

在詞典中a

from datetime import datetime

a = {"ID":3, "CITY":"ATLANTIS", "FOUNDATION":datetime(2014,10,12), "COLLAPSE":datetime(2010,10,12), "REGENERATE":datetime(2011,10,12)}

您將如何獲得該字典中日期最早的值(在本例中為"COLLAPSE":datetime(2010,10,12) )? 請記住,並非所有值都具有相同的數據類型。

如果你想要最早的日期,你想在這里使用min() ,而不是max() 時間較早的日期時間排在較晚的日期時間之前。

您需要在此處使用可調用的自定義key ,並為不是datetime對象的任何值返回datetime.max以打折該鍵:

from datetime import datetime

min(a.iteritems(),
    key=lambda i: i[1] if isinstance(i[1], datetime) else datetime.max)

這將返回鍵和值。

要獲取密鑰,請使用:

min(a, key=lambda k: a[k] if isinstance(a[k], datetime) else datetime.max)

僅就價值而言:

min(a.itervalues(),
    key=lambda v: v if isinstance(v, datetime) else datetime.max)

在所有情況下,只有獲取要比較的值的確切語法不同。

演示:

>>> from datetime import datetime
>>> a = {"ID":3, "CITY":"ATLANTIS", "FOUNDATION":datetime(2014,10,12), "COLLAPSE":datetime(2010,10,12), "REGENERATE":datetime(2011,10,12)}
>>> min(a.iteritems(),
...     key=lambda i: i[1] if isinstance(i[1], datetime) else datetime.max)
('COLLAPSE', datetime.datetime(2010, 10, 12, 0, 0))
>>> min(a, key=lambda k: a[k] if isinstance(a[k], datetime) else datetime.max)
'COLLAPSE'
>>> min(a.itervalues(),
...     key=lambda v: v if isinstance(v, datetime) else datetime.max)
datetime.datetime(2010, 10, 12, 0, 0)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM