按嵌套字段对JSON数据排序
创始人
2024-11-04 15:00:30
0

要按嵌套字段对JSON数据进行排序,可以使用Python的sorted函数和lambda函数来实现。下面是一个示例代码:

import json

def sort_nested_field(data, field):
    # 使用lambda函数根据指定的字段进行排序
    sorted_data = sorted(data, key=lambda x: x.get(field))
    return sorted_data

# 示例JSON数据
json_data = '''
[
    {
        "name": "John",
        "age": 30,
        "address": {
            "city": "New York",
            "state": "NY"
        }
    },
    {
        "name": "Alice",
        "age": 25,
        "address": {
            "city": "Los Angeles",
            "state": "CA"
        }
    },
    {
        "name": "Bob",
        "age": 35,
        "address": {
            "city": "San Francisco",
            "state": "CA"
        }
    }
]
'''

# 将JSON数据解析为Python对象
data = json.loads(json_data)

# 按嵌套字段进行排序
sorted_data = sort_nested_field(data, 'address.city')

# 打印排序后的结果
for item in sorted_data:
    print(item)

运行以上代码会输出按address.city字段排序后的JSON数据:

{'name': 'Bob', 'age': 35, 'address': {'city': 'San Francisco', 'state': 'CA'}}
{'name': 'Alice', 'age': 25, 'address': {'city': 'Los Angeles', 'state': 'CA'}}
{'name': 'John', 'age': 30, 'address': {'city': 'New York', 'state': 'NY'}}

在示例代码中,sort_nested_field函数接受一个JSON数据列表和一个字段作为参数。lambda函数用于从每个数据项中获取指定的字段值,然后sorted函数根据这个字段值对数据进行排序。最后,打印排序后的结果。

相关内容

热门资讯

七分钟辅助!丽水茶苑苹果手机辅... 七分钟辅助!丽水茶苑苹果手机辅助,本来是真的有辅助教程(有挂方式)1、实时丽水茶苑苹果手机辅助透视辅...
第一分钟辅助!闲来辅助神器下载... 第一分钟辅助!闲来辅助神器下载2022,好像真的有辅助方法(有挂教程)1、不需要AI权限,帮助你快速...
九分钟辅助!丽水都莱辅助工具试... 九分钟辅助!丽水都莱辅助工具试用,确实存在有辅助神器(有挂方法)九分钟辅助!丽水都莱辅助工具试用,确...
第一分钟辅助!蛮王辅助器,好像... 第一分钟辅助!蛮王辅助器,好像是有辅助方法(有挂教学)1、首先打开蛮王辅助器辅助器下载最新版本,在蛮...
第六分钟辅助!潮汕汇挂,一贯真... 第六分钟辅助!潮汕汇挂,一贯真的是有辅助插件(有挂辅助)1、这是跨平台的潮汕汇挂轻量版有透视,在线的...
六分钟辅助!微信开心泉州辅助器... 六分钟辅助!微信开心泉州辅助器,一直有辅助器(有挂教学)1、下载好微信开心泉州辅助器透视辅助下载之后...
第3分钟辅助!佛手十三道破解版... 第3分钟辅助!佛手十三道破解版安卓,竟然真的有辅助攻略(有挂存在)1、让任何用户在无需佛手十三道破解...
2分钟辅助!sohoo竞技联盟... 2分钟辅助!sohoo竞技联盟辅助,切实真的有辅助脚本(有挂技术)1.sohoo竞技联盟辅助 选牌创...
第8分钟辅助!心悦手游辅助器,... 第8分钟辅助!心悦手游辅助器,原来真的是有辅助技巧(确实有挂);1、每一步都需要思考,不同水平的挑战...
第十分钟辅助!广东雀神祈福真的... 第十分钟辅助!广东雀神祈福真的有用吗,都是是有辅助技巧(有挂方略)1、下载好广东雀神祈福真的有用吗透...