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

在 KeyError 中使用嵌套 for 循环从嵌套字典中检索项目

在 KeyError 中使用嵌套 for 循环从嵌套字典中检索项目

跃然一笑 2022-01-11 16:12:13
我需要系统地访问嵌套在第 3 级字典中的列表中的字典,如下所示:responses = {'1': {'responses': [{1st dict to be retrieved}, {2nd dict to be retrieved}, ...]},             '2': {'responses': [{1st dict to be retrieved}, {2nd dict to be retrieved}, ...]}, ...}我需要取消嵌套并将这些嵌套的字典转换为数据框,因此最终结果应如下所示:responses = {'1': df1,             '2': df2, ...}为了实现这一点,我构建了一个 for 循环,以便遍历第一级的所有键。在该循环中,我使用另一个循环将嵌套字典中的每个项目提取到一个名为的新空列表中responses_df:responses_dict = {}for key in responses.keys():    for item in responses[key]['responses']:        responses_dict[key].update(item)但是,我得到:KeyError: '1'如果我在字典中的一个键上单独使用内部循环,它就可以工作,但这并没有真正帮助我,因为数据来自 API,并且必须在生产中每隔几分钟动态更新一次。将结果转换为数据帧的 nex 循环如下所示:for key in responses_dict:     responses_df[key] = pd.DataFrame.from_dict(responses_dict[key], orient='index')但是自从第一次操作失败以来,我还没有尝试过。
查看完整描述

3 回答

?
qq_遁去的一_1

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

试试这个:


from collections import defaultdict      


responses_dict = defaultdict(dict) # instead of {}

然后你的代码就可以工作了。


查看完整回答
反对 回复 2022-01-11
?
LEATH

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

其实responses_dict[key]哪里key=1不存在。


所以,当你只是做print(responses_dict[key])你会得到相同的错误,1是不是一个关键dict,并update没有使用,因为它应该是。


尝试以下语法:


responses_dict = {}


for key in responses.keys():

    print(key)

    for item in responses[key]['responses']:

        responses_dict.update(key = item)


查看完整回答
反对 回复 2022-01-11
?
饮歌长啸

TA贡献1951条经验 获得超3个赞

试试这个:


responses = {'1': {'responses': [{'a': 1, 'b': 2}, {'c': 3, 'd': 4}]},

             '2': {'responses': [{'e': 5}, {'f': 6}]}}


result = {k: pd.DataFrame(chain.from_iterable(v['responses'])) for k, v in responses.items()}


for df in result.values():

    print(df, end='\n\n')

输出:


   0

0  a

1  b

2  c

3  d


   0

0  e

1  f


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

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号