Python字典排序、字典列表排序、嵌套字典排序

python字典是常用的数据结构,经常用到各种python字典的排序,记录一下不同字典排序的方法。

正常字典排序

正常的字典我们都知道,其排序如下:

    a={100:1,101:0,102:2}
    b=sorted(a.items(),key=lambda x:x[1])

输出:

[(101, 0), (100, 1), (102, 2)]

理解了上面这个key的含义,lambda可以理解为一个函数,输出为x:x[1],即字典的第一个值,合起来就是以字典的第一个值作为key排序。所以嵌套字典就是按如下进行排序

嵌套字典排序

如果是嵌套字典

a={100:{'x':1,'y':2},101:{'x':2,'y':0},102:{'x':0,'y':3}}

排序如下

a={100:{'x':1,'y':2},101:{'x':2,'y':0},102:{'x':0,'y':3}}
b=sorted(a.items(),key=lambda x:x[1]['x'])

x[1]表示{‘x’:1,‘y’:2},那么x[1][‘x’]就代表按’x’排序,排序结果如下:

[(102, {'x': 0, 'y': 3}), (100, {'x': 1, 'y': 2}), (101, {'x': 2, 'y': 0})]

如果想要设置主序和次序,可以如下:

key=lambda item: (-item[1][3], item[1][1], -item[1][2]))

字典列表排序

字典列表形如:

a = [{'x': 0, 'y': 3}, {'x': 1, 'y': 2},{'x': 2, 'y': 0}]

排序如下:

a.sort(key=lambda i: i["x"],reverse=True)

常用场景举例

在某些应用场景中需要根据单词在字符串中出现的位置对单词列表排序进行排序

words_lst = ["Beijing", "Shanghai", "Nanjing", "Guangzhou"]
s = "犯罪嫌疑人曾在Guangzhou作案,辗转Beijing,之后流窜到Nanjing,最后曾在Shanghai现身后消失"

我们需要将words_lst中的地名根据在句中出现的先后顺序进行排序,代码如下:

words_lst.sort(key=lambda i: re.search(i, s, re.IGNORECASE).span(), reverse=False)

输出

['Guangzhou', 'Beijing', 'Nanjing', 'Shanghai']
  • 4
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值