• python字典按照 值进行排序 sorted


    python字典按照 值进行排序

    d = {'a': 1, 'b': 4, 'c': 2, 'f' : 12}

    d = {'a': 1, 'b': 4, 'c': 2, 'f' : 12}
     
    # 第一种方法,key使用lambda匿名函数取value进行排序
    a = sorted(d.items(), key=lambda x: x[1])
    a1 = sorted(d.items(),key = lambda x:x[1],reverse = True)
    print(a)
    print(a1)

    打印结果是:

    [('a', 1), ('c', 2), ('b', 4), ('f', 12)]
    [('f', 12), ('b', 4), ('c', 2), ('a', 1)]

    # key使用lambda匿名函数按键进行排序
    a2 = sorted(d.items(),key = lambda x:x[0])
    print(a2)

    结果:  [('a', 1), ('b', 4), ('c', 2), ('f', 12)]

    # 第二种方法使用operator的itemgetter进行排序
    import operator
    b = sorted(d.items(), key=operator.itemgetter(1))
    print(b)

    结果: [('a', 1), ('c', 2), ('b', 4), ('f', 12)]

    # 第三种方法讲key和value分装成元祖,在进行排序
    f = zip(d.keys(), d.values())
    c = sorted(f)
    print(c)

    结果:  [('a', 1), ('b', 4), ('c', 2), ('f', 12)] 

    这是一个非常骚的操作:

    l = input()
    d = {}
    for i in l:
        if i in d.keys():
            d[i] += 1
        else:
            d[i] = 1
    # sorted(d, key=lambda x: (-x[1], x[0]), reverse=False)
    for k, v in sorted(d.items(), key=lambda x: (-x[1], x[0]), reverse=False):
        print(k, end='')

    x[1] 代表的是 字典的value(也就是每个字母的统计数量),

    -x[1]代表的是字典value的相反数;

    默认的sorted是升序,  从小到大, -3  -2  -1  0  1  2  这样。

    这里的reverse有点画蛇添足了。没必要。

    # 默认就是升序  先对字典的value进行升序,排序,如果遇到相同的数字,则对字典的key进行升序排序
    ans1 = sorted(ansDic.items(),key = lambda x:(-x[1], x[0]))  

  • 相关阅读:
    手搭手zabbix5.0监控redis7
    Weblogic XMLDecoder 远程代码执行漏洞 CVE-2017-10271 漏洞复现
    解析java中的字面量和字符类型
    Kotlin的协程:flow
    Apache Doris 基础 -- 部分数据类型及操作
    golang gin单独部署vue3.0前后端分离应用
    docker安装minio
    .NET Conf China 2023 活动纪实 抢先看
    StarNet实战:使用StarNet实现图像分类任务(一)
    HTML案例-1.标签练习
  • 原文地址:https://blog.csdn.net/Hodors/article/details/126072981