百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

使用Python 获取多级字典(Json)格式所有Key、Value

off999 2025-06-10 17:27 68 浏览 0 评论

在编程数据处理时,经常能碰到多级包含多类型的字典,例如下图:

客户要求取到所有根部key,value并写入DataFrame中,下面用我的方法来实现:

#新建存放key,value的数组
data = []
#重名计数变量
name_count=1
other_count=1
#取到字典
A=eval(response.text)
d=A["data"]
#循环遍历字典
for k, v in d.items():
    #print(k,v)
    if isinstance(v, dict):
        # 如果字典中的值是字典类型,继续判断是否数组
        for sub_k, sub_v in v.items():
            #print(type(sub_v))
            if isinstance(sub_v, list):
                #print(sub_v)
                #如果时数组则循环数组
                for sub_1_lst in sub_v:
                    #判断数组中的字典类型
                    if isinstance(sub_1_lst, dict):
                        #print(list(sub_v[0].keys()))
                        #继续循环遍历数组中的每个字典
                        for sub_1_k, sub_1_v in sub_1_lst.items():
                            #print(sub_1_k, sub_1_v)
                            #以下时重名判断,根据需要自定义
                            if sub_1_k=="name" :
                                data.append(( sub_1_k+str(name_count), sub_1_v))
                                name_count+=1
                                
                            elif sub_1_k=="riskPremSum":
                                data.append(( sub_1_k+str(other_count), sub_1_v))
                                other_count+=1
                            else:
                                data.append(( sub_1_k, sub_1_v))                  
    #如果不是字典则再次判断是否时数组                                          
    elif isinstance(v, list):
        # 如果字典中的值是列表类型
        for i, item in enumerate(v):
            print(i,item)
            #继续循环遍历数组中的每个字典
            if isinstance(item, dict):
                # 如果列表中的元素是字典类型,
                for sub_k, sub_v in item.items():
                    #以下时重名判断,根据需要自定义
                    if sub_k=="name" :
                        data.append((sub_k+str(name_count), sub_v))
                        name_count+=1
                    elif sub_k=="riskPremSum":
                        data.append((sub_k+str(other_count), sub_v))
                        other_count+=1
                    else:
                        data.append((sub_k, sub_v))
            else:
                data.append((k + '.' + str(i), item))
    #如果非字典非数组则直接写入   
    else:
        if k=="name" :
            data.append((k+str(name_count), v))
            name_count+=1
        elif k=="riskPremSum":
            data.append((k+str(other_count), v))
            other_count+=1
        else:
            data.append((k, v))
        

结果

写入DataFrame

df=pd.DataFrame({"a":[]})
for ss in data:
    #print(ss)
    df.loc[0,ss[0]]=ss[1]
df  

以上是我个人的笨方法,整体思路就是逐级读取判断,弊端就是字典的层数少,chatGPT给我的是递归方法,我没太理解,同学们如果还有更好的方法欢迎指导,谢谢!

相关推荐

flash下载安卓版下载(flashget安卓下载)

通过iTunes上的iTunesstore或者iPhone上的AppStore下载要是越狱版本91助手也可以下载而且有更多免费的游戏就是说你的电脑没有flash插件,需要安装flash插件才能...

模拟农场20(模拟农场20国产收割机)
  • 模拟农场20(模拟农场20国产收割机)
  • 模拟农场20(模拟农场20国产收割机)
  • 模拟农场20(模拟农场20国产收割机)
  • 模拟农场20(模拟农场20国产收割机)
电子公章印章在线制作(电子公章印章在线制作教程)

首先说明:电子公章制作需要有授权才能够进行!公章做成电子版可以通过Word来进行。具体方法步骤如下:1、准备工作:首先需要你(妳)将实体印章拍成图片格式上传到计算机保存桌面。2、制作操作:打开计算机办...

12306掐点抢票技巧(抢不到票去人工窗口能买到吗)

1、提前做好准备:在12306官网上预订车票前,先登录账号并保存好乘车人信息和常用联系人信息。此外,在购票日前,可以提前进行车次和座位的查询和选择。2、时间选择:00:00到08:00。3、车次选择:...

qq炫舞官网掌上炫舞(qq炫舞官方网站最新活动)

你好,进入掌上炫舞商城的方法如下:1.打开掌上炫舞游戏,进入游戏主界面。2.点击屏幕左下角的“商城”按钮。3.进入商城后,可以选择购买游戏中的道具、礼包等物品。4.在商城中选择要购买的物品后,...

西瓜音乐免费听(西瓜音乐免费听歌的app)
西瓜音乐免费听(西瓜音乐免费听歌的app)

TOP15:少年原唱:梦然热度值:1,013,022我还是从前那个少年没有一丝丝改变抖音梦然-《少年》mvTOP14:好想爱这个世界啊原唱:华晨宇热度值:1,013,096不想离开当你的笑容绽开这世界突然填满色彩华晨宇新歌《好想...

2026-02-03 17:43 off999

酷酷狗app正版下载安装(酷狗音乐下载最新版酷)

卖八个金,目前六阶的酷酷狗以及松鼠都是属于不错的两个战宠,酷酷狗的平A伤害十分之高,与黑霸对比也不会落下风,当我们使用技能还可以增加大量伤害,大约等于黑霸的两倍。虽然说松鼠的伤害对比酷酷狗来说十分一...

迅雷app(迅雷app下载安装官网手机版)
迅雷app(迅雷app下载安装官网手机版)

首先打开迅雷app,点击我的转存然后点击我们下载的文件然后点击左下角下载就好拉迅雷下载完的视频是直接保存到我的转存里。如果要想再把我的转存里面文件,下载到手机上,首先选择底部云盘图标进入我的转存页面,找到里面要下载的视频,勾选打√,下面会出...

2026-02-03 17:03 off999

苹果itunes在哪里打开(itunes从哪打开)
苹果itunes在哪里打开(itunes从哪打开)

1、将你的iPhone关机。2、同时按住开关机键和Home键。3、当你看见白色的苹果Logo时,请松开开关机键,并继续保持按住Home键。4、开启iTunes,等待其提示你进入恢复模式后,即可按住键盘上的Shift键,点击“恢复”,选择相应...

2026-02-03 16:51 off999

如何申请qq号(如何申请qq号详细步骤)

只需在网页上申请即可获得QQ号码或Email帐号,无需任何费用。为了打击使用自动机进行批量申请QQ帐号的行为,我们对网页申请进行了部分限制,有可能对少数申请造成影响。手机免费申请(仅支持申请QQ号码)...

visual studio官网下载(microsoft visual studio官方下载)

以下是VisualStudio2017的下载和安装步骤:1.打开浏览器,并在搜索引擎中搜索"VisualStudio2017下载"。2.找到微软官方的VisualStud...

手机可编辑的办公软件(手机可编辑的办公软件下载)
  • 手机可编辑的办公软件(手机可编辑的办公软件下载)
  • 手机可编辑的办公软件(手机可编辑的办公软件下载)
  • 手机可编辑的办公软件(手机可编辑的办公软件下载)
  • 手机可编辑的办公软件(手机可编辑的办公软件下载)
cad2014破解版激活教程(cad 2014破解版怎么样激活)
cad2014破解版激活教程(cad 2014破解版怎么样激活)

步骤如下:1.打开CAD2014,点击激活,勾选同意协议之后它会告诉您,您的序列号是错误的,这时点击关闭等一会再点击激活即可;2.在激活界面中选择“我拥有一个Autodesk激活码”;3.启动对应版本的XFORCEKeygen32bit...

2026-02-03 15:51 off999

electricity(electricity翻译)

electricity[英][??lek?tr?s?ti][美][?l?k?tr?s?ti,?il?k-]n.电力;电流,静电;高涨的情绪;紧张;以上结果来自金山词霸例句:1.Article31pow...

腾讯游戏实名认证中心官网(腾讯游戏实名认证官网首页)

QQ游戏实名注册和防沉迷系统设置方法:第一步:登录实名注册和防沉迷系统网站(http://jkyx.qq.com/web2010/authoriz.htm);第二步:填写实名制信息;第三步:等待审核,...

取消回复欢迎 发表评论: