如何重新排列字典键的顺序? - python

我遇到了要重新排列字典键顺序的问题。我有一个具有env = [key1, key2, key3]的数组,然后在循环中,这些键从数组中获取并馈送到字典中; dict_result。
dic_result以以下格式显示这些env键在字典中的顺序(即使我未使用任何排序函数,也基于key1,key2、3名称的字母顺序):

{'name': {'key2': [val1, val2, val3], 'key1': [], 'key3': [val1, val2]},
'name1': {'key2': [val1, val2, val3], 'key1': [], 'key3': [val1, val2]},
...
}

for k in dict_result['name'].keys():
    //performing checks 

我想将dict_result [name]的嵌套键顺序更改为:

{'name': {'key3': [val1, val2]}, 'key2': [],'key1': [val1, val2, val3]}

我确实使用内置函数reversed()进行了尝试,但似乎创建了一个迭代器,该迭代器更改了我现有代码和for循环中的某些逻辑,该循环遍历这些字典env键并根据其值执行检查/验证。
我现在了解到,常规dict不会跟踪插入顺序,并且对其进行迭代会以任意顺序给出值。

如果有一种更简单的方法可以让字典完全按照从数组中馈入/摄取它们的顺序来使用env键,请提供帮助,即key1,key2,key3,或者可以将其反转为具有key3,key2,key1。
但是不要使用现有的方式来根据实际键名显示字母顺序。

参考方案

一旦对键进行排序,OrderedDict可用于维持插入顺序。

import collections

data = {'name': {'key3': [1, 2, 3], 'key2': [], 'key1': [5, 6]}}
data['name'] = sorted(data['name'].items())
order_dict = collections.OrderedDict(data)
print(order_dict)

O / P:

OrderedDict([('name', [('key1', [5, 6]), ('key2', []), ('key3', [1, 2, 3])])])

在返回'Response'(Python)中传递多个参数 - python

我在Angular工作,正在使用Http请求和响应。是否可以在“响应”中发送多个参数。角度文件:this.http.get("api/agent/applicationaware").subscribe((data:any)... python文件:def get(request): ... return Response(seriali…

Python exchangelib在子文件夹中读取邮件 - python

我想从Outlook邮箱的子文件夹中读取邮件。Inbox ├──myfolder 我可以使用account.inbox.all()阅读收件箱,但我想阅读myfolder中的邮件我尝试了此页面folder部分中的内容,但无法正确完成https://pypi.python.org/pypi/exchangelib/ 参考方案 您需要首先掌握Folder的myfo…

python JSON对象必须是str,bytes或bytearray,而不是'dict - python

在Python 3中,要加载以前保存的json,如下所示:json.dumps(dictionary)输出是这样的{"('Hello',)": 6, "('Hi',)": 5}当我使用json.loads({"('Hello',)": 6,…

R'relaimpo'软件包的Python端口 - python

我需要计算Lindeman-Merenda-Gold(LMG)分数,以进行回归分析。我发现R语言的relaimpo包下有该文件。不幸的是,我对R没有任何经验。我检查了互联网,但找不到。这个程序包有python端口吗?如果不存在,是否可以通过python使用该包? python参考方案 最近,我遇到了pingouin库。

Python ThreadPoolExecutor抑制异常 - python

from concurrent.futures import ThreadPoolExecutor, wait, ALL_COMPLETED def div_zero(x): print('In div_zero') return x / 0 with ThreadPoolExecutor(max_workers=4) as execut…