我写了这段代码:
n=5
dizN={}
for q in range(0,n+1):
h=n-q
dizN['a'+str(q)+'p'+str(h)]=0
创建这样的字典:
dizN
Out[120]: {'a0p5': 0, 'a1p4': 0, 'a2p3': 0, 'a3p2': 0, 'a4p1': 0, 'a5p0': 0}
请注意,“n”是我的代码的基本参数。如您所见,dict键字符串中存在的整数之和总是= n(在这种情况下= 5,其中n = 5)。
对我来说(对于我的程序中更为困难的目的)来说,对于每个人都可以选择的dict,这个dict是以这种方式排序的:
{'a0p(n)': 0, 'a1p(n-1)': 0, ....., 'a(n-1)p1': 0, 'a(n)p0': 0}
我的代码没问题,但仅适用于n< 10。 如果n>≥10,则会发生这种情况:(n = 12)dizN:
Out[121]:
{'a0p12': 0,
'a10p2': 0,
'a11p1': 0,
'a12p0': 0,
'a1p11': 0,
'a2p10': 0,
'a3p9': 0,
'a4p8': 0,
'a5p7': 0,
'a6p6': 0,
'a7p5': 0,
'a8p4': 0,
'a9p3': 0}
正如您所见,解释器遵循字母数字排序;
任何人都知道是否有办法获得以这种方式排序的同一个字典:
{'a0p12': 0,
'a1p11': 0,
'a2p10': 0,
'a3p9': 0,
'a4p8': 0,
'a5p7': 0,
'a6p6': 0,
'a7p5': 0,
'a8p4': 0,
'a9p3': 0,
'a10p2': 0,
'a11p1': 0,
'a12p0': 0}
我知道字典基本上是不可排序的,但我希望有人知道一些技巧来实现我的目的:)
非常感谢!
答案 0 :(得分:1)
dicts 无序,因此要获得订单,您必须对项目进行排序并使用 OrderedDict 来维护已排序的订购。要获得所需的顺序,可以从整数组创建元组,以便按字典顺序排序为整数:
from itertools import groupby
from collections import OrderedDict
d = {'a0p12': 0, 'a10p2': 0, 'a11p1': 0, 'a12p0': 0, 'a1p11': 0, 'a2p10': 0,
'a3p9': 0, 'a4p8': 0, 'a5p7': 0, 'a6p6': 0, 'a7p5': 0, 'a8p4': 0, 'a9p3': 0}
def key_func(x):
"""'a0p12' -> (0, 12)"""
return tuple(int("".join(v)) for k,v in groupby(x[0], key=str.isdigit) if k)
od = OrderedDict(sorted(d.items(), key=key_func))
print(od)
哪会给你:
OrderedDict([('a0p12', 0), ('a1p11', 0), ('a2p10', 0), ('a3p9', 0),
('a4p8', 0), ('a5p7', 0), ('a6p6', 0), ('a7p5', 0), ('a8p4', 0),
('a9p3', 0), ('a10p2', 0), ('a11p1', 0), ('a12p0', 0)])
您还可以使用正则表达式查找数字组:
from collections import OrderedDict
import re
d = {'a0p12': 0, 'a10p2': 0, 'a11p1': 0, 'a12p0': 0, 'a1p11': 0, 'a2p10': 0,
'a3p9': 0, 'a4p8': 0, 'a5p7': 0, 'a6p6': 0, 'a7p5': 0, 'a8p4': 0, 'a9p3': 0}
def key_func(x,patt=re.compile("\d+")):
"""'a0p12' -> (0, 12)"""
return tuple(map(int, patt.findall(x[0])))
od = OrderedDict(sorted(d.items(), key=key_func))
print(od)