关于字典排序的问题
请问各位大佬关于下面这种类型的字典的key排序该如何解决呢?{:10_254:}字典的key格式如下 value的值都不一样 以下全部省略为xxx
sample = {‘1_a’: xxx, ‘1_b’: xxx, ‘1_k’: xxx, ‘2_a’:xxx, ‘2_b’: xxx, ‘2_k’:xxx, ‘3_a’: xxx, ‘3_b’:xxx, ‘3_k’: xxx, .......}
希望得到如下结果n_a的key在最前面 其次为n_k,最后是n_b的key
result = {‘1_a’:xxx, ‘2_a': xxx, ‘3_a’:xxx ,‘1_k’:xxx, ‘2_k’: xxx, ‘3_k’: xxx, ‘1_b’: xxx, .....}
本帖最后由 hrp 于 2021-2-27 12:06 编辑
snowzkr 发表于 2021-2-27 00:57
谢谢 不过感觉结果不太对 希望得到的结果是下面这样._k的key要在_b前面比较头疼
{‘1_a': 123, '2_a’ ...
键的数字是按升序排序,但是字母部分既不是升序也不是降序排列,你也没给排序规则或者算法,只能自定义一个顺序表去排序了。
# coding: utf-8
import re
sample = {'1_a': 123, '1_b': 456, '1_k': 789, '2_a': 12, '2_b': 34, '2_k': 56, '3_a': 78, '3_b':90, '3_k': 1}
# 自定义顺序, 可根据需要进行更改
order = 'a', 'k', 'b'
def sortkey(s):
s = s
lto = re.search(r'_(+)$', s)
if not lto:
return s[::-1]
lt = lto.group(1)
if lt in order:
return s.replace(lto.group(0), str(order.index(lt)))[::-1]
return s[::-1]
sample = dict(sorted(sample.items(), key=sortkey))
print(sample) 字典为什么要排序?你是对字典有什么误解吗 我只能把键排个序,剩下的也不知怎么办d = {'b_0':'XXX', 'a_2':'XXX', 'a_3':'XXX', 'b_1':'XXX', 'b_2':'XXX'}
def keysintide(d):
list_ = []
for k, v in d.items():
list_.append(k)
list_.sort()
return list_{:10_266:} 本帖最后由 hrp 于 2021-2-26 21:49 编辑
Python3.6以前字典是无序的,3.6及以后的版本,字典可以保持创建时的顺序。
# coding: utf-8
sample = {'1_a': 123, '1_b': 456, '1_k': 789, '2_a': 12, '2_b': 34, '2_k': 56, '3_a': 78, '3_b':90, '3_k': 1}
sample = dict(sorted(sample.items(), key=lambda x: x[::-1]))
print(sample) from collections import OrderedDict
sample = {'1_a': 123, '1_b': 456, '1_k': 789, '2_a': 12, '2_b': 34, '2_k': 56, '3_a': 78, '3_b':90, '3_k': 1}
o_sample= OrderedDict(sorted(data.items(), key=lambda x: x))
当然 python高版本字典已经可以代替OrderedDict了 本帖最后由 snowzkr 于 2021-2-27 01:18 编辑
洋洋痒 发表于 2021-2-26 20:38
字典为什么要排序?你是对字典有什么误解吗
上面需求是这样…最终的值是以json形式给前端去处理的。所以也没有办法 只能按需求去整{:10_266:}{:10_266:} hrp 发表于 2021-2-26 21:27
Python3.6以前字典是无序的,3.6及以后的版本,字典可以保持创建时的顺序。
谢谢 不过感觉结果不太对 希望得到的结果是下面这样._k的key要在_b前面比较头疼
{‘1_a': 123, '2_a’: 12, '3_a': 78, '1_k’: xxx, '2_k': xxx, '3_k': xxx, '1_b': xxx, '2_b':xxx, '3_b': xxx} 柿子饼同学 发表于 2021-2-26 21:07
我只能把键排个序,剩下的也不知怎么办
感谢 _k的key要在_b的key的前面这个问题比较麻烦。不知道有什么好的办法 kogawananari 发表于 2021-2-26 21:36
from collections import OrderedDict
sample = {'1_a': 123, '1_b': 456, '1_k': 789, '2_a': 12, '2_b ...
谢谢 不过希望得到的结果是
{'1_a': 123, '2_a': 12, '3_a': 78,'1_k': 789, '2_k’: 56, '3_k': 1, '1_b': 456, '3_b':34, '3_b': 90}
{:10_266:}
有一个想法
请看到最后,这是一个没有办法的办法,先变成数组再 sort,然后填入一个新的字典
可以使用数组的 sort 方法,先把键和值提取出来
塞进一个列表里,然后使用 sort 方法排序
再取出列表里面的键和值,生成一个新的字典
新生成的字典就是按照顺序的
Daniel_Zhang 发表于 2021-2-27 01:39
有一个想法
请看到最后,这是一个没有办法的办法,先变成数组再 sort,然后填入一个新的字典
# coding: utf-8
list1 = []
new_dict = {}
sample = {'1_a': 123, '2_d': 111, '1_b': 456, '1_k': 789, '2_a': 12,
'2_b': 34, '2_k': 56, '3_a': 78, '8_b': 12, '3_b': 90, '3_k': 1}
for key, value in sample.items():
list2 = []
list2.extend()
list1.append(list2)
list1.sort()
print(list1)
for each in range(len(list1)):
new_dict] = list1
print(new_dict)
本帖最后由 kogawananari 于 2021-2-27 03:13 编辑
snowzkr 发表于 2021-2-27 01:01
感谢 _k的key要在_b的key的前面这个问题比较麻烦。不知道有什么好的办法
按照'_'分割数组 倒置后排序{:10_331:}
sample = {'1_a': 123, '2_d': 111, '1_b': 456, '1_k': 789, '2_a': 12,
'2_b': 34, '2_k': 56, '3_a': 78, '8_b': 12, '3_b': 90, '3_k': 1}
new_dict = dict(sorted(sample.items(), key=lambda x: "".join(x.split('_')[::-1])))
print(new_dict)
满意没{:10_293:} 下面这样写法可以得到想要的结果…
_a的键在最前 其次为_k的键 最后是_b的键的顺序。 不过写法套了2个循环。 不知可否有什么优化的写法 望大神们指点。
from collections import OrderedDict
sample = {'1_a': 123, '2_k': 12, '3_a': 78,'1_k': 789, '2_b': 56, '3_b':123, '1_b': 456, '2_a':34, '3_k': 90}
target_list = ['a', 'k', 'b']
json_dict = OrderedDict()
for i in target_list:
for k,v in sample.items():
if k.endswith(i):
json_dict.update({k:v})
print(json_dict)
本帖最后由 Stubborn 于 2021-2-27 20:04 编辑
*a -> *k ->*b
只需要分类还是分类之后,还要在排序?
先分类,然后在用sorted进行key的排序,然后用有序字典OrderedDict类添加把
>>> a = {'1_a':1, '3_a':2, '2_a':3}
>>> sorted(a.keys())
['1_a', '2_a', '3_a']
页:
[1]