繁体   English   中英

按特定值对python中的JSON进行排序

[英]Sorting JSON in python by a specific value

您好我试图通过python中的“data_two”字段对以下JSON进行排序:

{
"1.2.3.4": {
    "data_one": 1,
    "data_two": 8,
    "list_one": [],
    "list_two": [
        "item_one"
    ],
    "data_three": "string1"
},
"5.6.7.8": {
    "data_one": 1,
    "data_two": 9,
    "list_two": [
        "item_one"
    ],
    "data_three": "string1",
    "data_four": "string2",
    "data_five": "string3"
}
}

我尝试过使用类似的东西

entries = sorted(json_data['1.2.3.4'], key=lambda k: k['data_two'])

然而,我没有太多运气/不断混淆。 我的最终目标是通过“data_two”值对所有json条目进行排序,其中JSON中每个条目的键是一个随机的IP字符串。 我是JSON世界的新手,请原谅我,如果这是一个简单的问题,任何帮助将不胜感激。

谢谢

如果你有过如何将数据汇总控制, 最好是有类型的字典列表 ,而IP将是数据字典中的 {..., 'ip': '127.0.0.1'}而不是关键在容器父dict中

转换为保留元素顺序的容器

您只能对维护元素顺序的结构进行排序,例如list例如,存在像OrderedDict一样维护顺序的dict实现

您可以随时转换为那些(如果慢/大数据可能不是您的首选)

转换为列表[(键,值),...]或列表[value,...]

一种可能的方法是检索dict中的所有值,然后返回这些值的列表,按您选择的字段排序

您还可以对by ips_data.items()返回的(key, value) by ips_data.items() ,但这将创建一个新列表。 key是IP, value是IP数据

sorted_list_of_keyvalues = sorted(ips_data.items(), key=item[1]['data_two'])

上面的列表以[(key1, value1), (key2, value2), ...]

您还可以获取值并删除键

sorted_list_of_values = [item[1] for item in sorted_list_of_keyvalues]

此列表的形式为[value1, value2, ...]

请注意,您可能认为您只能按值而不是(键。值)进行排序,但您的数据中包含IP密钥,您可能希望保留它。

转换为OrderedDict

如果您绝对希望将结构保留为dict,则可以使用OrderedDict

from collections import OrderedDict
ordered_items = sorted(ips_data.items(), key=lambda item: item[1]['data_two'])
ordered_ips_data_dict = OrderedDict(ordered_items)

有序的dict行为就像一个dict,但是key和items迭代将保持元素的顺序。

或者,保留已排序的键列表,并按此顺序处理

或者,您可以将该字典的键排序到列表中,然后您可以按顺序处理该字典。 优点是您不必复制/转换数据

>>> ips_data = {
... "1.2.3.4": {
...     "data_one": 1,
...     "data_two": 8,
...     "list_one": [],
...     "list_two": [
...         "item_one"
...     ],
...     "data_three": "string1"
... },
... "5.6.7.8": {
...     "data_one": 1,
...     "data_two": 9,
...     "list_two": [
...         "item_one"
...     ],
...     "data_three": "string1",
...     "data_four": "string2",
...     "data_five": "string3"
... }
... }
>>> ips_data.keys()
['1.2.3.4', '5.6.7.8']
>>> ips = ips_data.keys()

现在,您可以按字段data_two对键进行排序

>>> sorted_ips = sorted(ips, key=lambda ip: ips_data[ip]['data_two'], reverse=True)
>>> sorted_ips
['5.6.7.8', '1.2.3.4']

排序后的键,您可以按照排序的键顺序执行您想要的dict,例如按此顺序处理它可能比将dict复制到像列表这样的新结构更有效

# Trivial example of processing that just puts the values into a list   
>>> [ips_data[ip] for ip in sorted_ips]
[{'data_three': 'string1', 'data_two': 9, 'data_five': 'string3', 'data_four': 'string2', 'list_two': ['item_one'], 'data_one': 1}, {'list_two': ['item_one'], 'data_two': 8, 'data_one': 1, 'data_three': 'string1', 'list_one': []}]
>>> 

看起来你尝试的非常接近。 下面将为您提供一个排序的元组列表,其中键位于第0位,值(位于字典中)位于第1位。 你应该能够使用它来做你想做的事情。

entries = sorted(json_data.items(), key=lambda items: items[1]['data_two'])

所以举个例子

{ "k1": {"data_one": 1, "data_two": 50 ...}, "k2": {"data_one": 50, "data_two": 2}}

会导致:

[("k2", {..."data_two": 2...}), ("k1", {..."data_two": 50...})]

希望有所帮助!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM