Python对Dict排序

python对dict进行排序:

result = sorted(my_dict.items(), key = lambda x:x[1], reverse=True)

如果对key排序,用x[0];默认的是从小到大排序,如果是从大到小,需要用reverse = True.
返回的result是一个list,不再是一个dict

words =  ["i", "love", "leetcode", "i", "love", "coding"]
result = sorted(words.items(), key = lambda x:x[1], reverse=True)
result

返回的是

[('i', 2), ('love', 2), ('coding', 1), ('leetcode', 1)]
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中的字典是一种无序的数据结构,即键值对的存储和访问没有固定的顺序。在Python 3.6之前的版本中,字典的顺序是不确定的,即使你按照一定的顺序插入键值对,遍历字典时也不能保证按照插入的顺序输出。 然而,在Python 3.6版本之后,字典的内部算法发生了改变,使得字典成为有序的数据结构。这意味着无需再关注字典的顺序性问题,可以按照插入的顺序遍历字典。 如果你想要使用有序字典,可以使用Python的collections模块中的OrderedDict类。OrderedDict是一种有序字典,它会按照插入的顺序存储键值对,并且可以按照插入的顺序进行遍历。以下是一个使用OrderedDict的例子: ```python import collections my_order_dict = collections.OrderedDict() my_order_dict["name"] = "lowman" my_order_dict["age"] = 45 my_order_dict["money"] = 998 my_order_dict["hourse"] = None for key, value in my_order_dict.items(): print(key, value) ``` 输出结果会按照插入的顺序输出键值对。 另外,如果你想要在Python 3.6之前的版本中实现字典的排序,可以使用列表和sort()方法来实现。你可以将键值对以元组的形式放入列表中,并使用sort()方法按照指定的排序规则进行排序。以下是一个示例代码: ```python l = [] l.append(("name", "lowman")) l.append(("age", 45)) l.append(("money", 998)) .append(("hourse", None)) l.sort(key=lambda x: x<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Python dict 排序](https://blog.csdn.net/weixin_43955170/article/details/119276566)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值