首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在具有混合类型值的字典中获得具有最大日期值的项?

如何在具有混合类型值的字典中获得具有最大日期值的项?
EN

Stack Overflow用户
提问于 2014-07-15 17:20:16
回答 1查看 5.6K关注 0票数 4

在字典a

代码语言:javascript
复制
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))?请记住,并非所有的值都是相同的数据类型。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-07-15 17:38:05

如果您想要最早的日期,您希望在这里使用min(),而不是max();在时间上较早的日期会在另一个时间之前排序,而后者则更晚。

您需要在这里使用可调用的自定义key,并对任何不是datetime对象的值返回datetime.max以折扣该键:

代码语言:javascript
复制
from datetime import datetime

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

这将返回键和值。

要获得密钥,请使用:

代码语言:javascript
复制
min(a, key=lambda k: a[k] if isinstance(a[k], datetime) else datetime.max)

就其价值而言:

代码语言:javascript
复制
min(a.itervalues(),
    key=lambda v: v if isinstance(v, datetime) else datetime.max)

在所有情况下,只有精确的语法才能得到要比较的值。

演示:

代码语言:javascript
复制
>>> 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)
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24764372

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档