为了账号安全,请及时绑定邮箱和手机立即绑定

如何根据日期范围从字典列表中过滤出子字典

如何根据日期范围从字典列表中过滤出子字典

慕码人2483693 2022-01-05 13:10:58
我需要根据日期范围从字典列表中过滤出子字典这是我的清单:[{'5-jan-2019': '34'}, {'10-jan-2019': '34'}, {'21-jan-2019': '12'}, {'25-jan-2019': '34'} , {'5-feb-2019': '34'}]我需要过滤掉一个日期范围内的所有子词典from_date-'5-jan-2019' and  to_date-'25-jan-2019'并将其添加到新字典中预期结果{    '5-jan-2019': '34',    '10-jan-2019': '34',    '21-jan-2019': '12',    '25-jan-2019': '34'}
查看完整描述

2 回答

?
慕森卡

TA贡献1806条经验 获得超8个赞

您希望 datetime.strptime 将字符串转换为 datetime 对象,然后您可以将它们相互比较。


from datetime import datetime


lst = [

    {'5-jan-2019': '34'},

    {'10-jan-2019': '34'},

    {'21-jan-2019': '12'},

    {'25-jan-2019': '34'},

    {'5-feb-2019': '34'},

    ]


dt_from_str = lambda dt: datetime.strptime(dt, '%d-%b-%Y')


start_date = dt_from_str('5-jan-2019')

end_date = dt_from_str('25-jan-2019')


new_dict = {}

for sub_dict in lst:

    for key, val in sub_dict.items():

        if start_date <= dt_from_str(key) <= end_date:

            new_dict[key] = val


print(new_dict)

输出:


{

    '5-jan-2019': '34',

    '10-jan-2019': '34',

    '21-jan-2019': '12',

    '25-jan-2019': '34',

}


查看完整回答
反对 回复 2022-01-05
?
慕仙森

TA贡献1827条经验 获得超7个赞

您可以使用该datetime模块来利用对象的内置比较方法(__lt__等)datatime.datetime:


import datetime

data = [{'5-jan-2019': '34'}, {'10-jan-2019': '34'}, {'21-jan-2019': '12'}, {'25-jan-2019': '34'} , {'5-feb-2019': '34'}]

start, end = '5-jan-2019', '25-jan-2019'

def d_form(d):

   months = ['jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec']

   _d, _m, _y = d.split('-')

   return datetime.datetime(int(_y), months.index(_m)+1, int(_d))


start, end = d_form(start), d_form(end)

final_result = [i for i in data if start <= d_form(list(i.keys())[0]) <= end]

输出:


[{'5-jan-2019': '34'}, 

 {'10-jan-2019': '34'}, 

 {'21-jan-2019': '12'}, 

 {'25-jan-2019': '34'}]


查看完整回答
反对 回复 2022-01-05
  • 2 回答
  • 0 关注
  • 121 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信