[英]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.