zoukankan      html  css  js  c++  java
  • python-列表包字典-根据字典的某一个键的值来进行排序

    python-列表包字典-根据字典的某一个键的值来进行排序

    列表包字典的数据结构

    要实现按照字典中的某一个键所对应的值进行排序

    有两种办法

    方法一,使用列表的sort方法

    由小到大排
    列表.sort(key=lambda 形参:形参[str键名称])
    
    由大到小排
    列表.sort(key=lambda 形参:形参[str键名称], reverse=True)
    

    方法二,使用sorted函数

    由小到大排序
    新列表 = sorted(列表,key=lambda 形参:形参[str键名称])
    
    由大到小排序
    新列表 = sorted(列表,key=lambda 形参:形参[str键名称], reverse = True)
    

    举例说明

    stuDictList = [
        {"name": "张飞", "power": 96, "tellegent": 30},
        {"name": "诸葛亮", "power": 40, "tellegent": 99},
        {"name": "周瑜", "power": 79, "tellegent": 93},
        {"name": "赵云", "power": 97, "tellegent": 86},
    ]
    
    print("原始的数据
    {}".format(stuDictList))
    # 原始的数据
    # [{'name': '张飞', 'power': 96, 'tellegent': 30}, {'name': '诸葛亮', 'power': 40, 'tellegent': 99}, {'name': '周瑜', 'power': 79, 'tellegent': 93}, {'name': '赵云', 'power': 97, 'tellegent': 86}]
    
    print("开始按照武力排序,由小到大")
    stuDictList.sort(key=lambda stu: stu["power"])
    print("排好序后新数据
    {}".format(stuDictList))
    # 开始按照武力排序,由小到大
    # 排好序后新数据
    # [{'name': '诸葛亮', 'power': 40, 'tellegent': 99}, {'name': '周瑜', 'power': 79, 'tellegent': 93}, {'name': '张飞', 'power': 96, 'tellegent': 30}, {'name': '赵云', 'power': 97, 'tellegent': 86}]
    
    print("开始按照智力值排序,由大到小")
    def func(ele):
        return ele["tellegent"]
    
    new_list = sorted(stuDictList, key=func, reverse=True)
    print("排序结果{}".format(new_list))
    # 开始按照智力值排序,由大到小
    # 排序结果[{'name': '诸葛亮', 'power': 40, 'tellegent': 99}, {'name': '周瑜', 'power': 79, 'tellegent': 93}, {'name': '赵云', 'power': 97, 'tellegent': 86}, {'name': '张飞', 'power': 96, 'tellegent': 30}]
    

    operator 模块

    import operator
    new_list = sorted(stuDictList, key=operator.itemgetter('tellegent'), reverse=True)
    print(new_list)
    
    # [{'name': '诸葛亮', 'power': 40, 'tellegent': 99}, {'name': '周瑜', 'power': 79, 'tellegent': 93}, {'name': '赵云', 'power': 97, 'tellegent': 86}, {'name': '张飞', 'power': 96, 'tellegent': 30}]
    

    原文链接:https://blog.csdn.net/ifubing/article/details/99607452

  • 相关阅读:
    面试题19:包含min函数的栈
    编程之美 计算字符串的相似度
    android 数据持久化——I/O操作
    SSD磁盘,CPU居高不下,高并发的情况下,是不是mysql解析器耗费的cpu资源高?
    Eclipse、MyEclipse优化,提高运行速度
    Sonar入门学习
    Oracle 生成指定范围内随机日期
    ios中的GCD
    如何使用Win8系统自带杀毒软件
    安装Ubuntu版本linux过程中没有提示设置root用户密码问题的解决办法
  • 原文地址:https://www.cnblogs.com/geoffreygao/p/12807805.html
Copyright © 2011-2022 走看看