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

  • 相关阅读:
    兴趣遍地都是,专注和持之以恒才是真正稀缺的
    vuecli2和vuecli3项目中添加网页标题图标
    vue+sentry 前端异常日志监控
    从零构建vue项目(三)--vue常用插件
    从零构建vue项目(一)--搭建node环境,拉取项目模板
    dbvisualizer安装
    TS学习笔记----(一)基础类型
    基于weui loading插件封装
    UI组件--element-ui--全部引入和按需引入
    vue_全局注册过滤器
  • 原文地址:https://www.cnblogs.com/geoffreygao/p/12807805.html
Copyright © 2011-2022 走看看