按自然顺序对字典关键字进行排序[重复项]
问题内容:
这个问题已经在这里有了答案 :
如何按键对字典排序?
(28个答案)
6年前关闭。
我想按“自然顺序”对字典键进行排序。如果我有带钥匙的字典
d = {"key1" : object, "key11" : object, "key2" : object, "key22" : object", "jay1" : object, "jay2" : object}
我想对这本字典进行排序,所以结果是:
d = { "jay1" : object, "jay2" : object, "key_1" : object, "key_2" : object, "key_11" : object, "key_22" : object"}
问题答案:
您可以将字典更改为OrderedDict:
import collections, re
d = {"key1" : 'object', "key11" : 'object', "key2" : 'object', "key22" : 'object', "jay1" : 'object', "jay2" : 'object'}
my_fun = lambda k,v: [k, int(v)]
d2 = collections.OrderedDict(sorted(d.items(), key=lambda t: my_fun(*re.match(r'([a-zA-Z]+)(\d+)',t[0]).groups())))
print(d2)
#reslt: OrderedDict([('jay1', 'object'), ('jay2', 'object'), ('key1', 'object'), ('key11', 'object'), ('key2', 'object'), ('key22', 'object')])
基本上,这里发生了什么,我将字符串分为“字符串”部分和数字部分。数字部分更改为int
,并且使用这两个值进行排序。