Python基于自定义方法的排序
Python基于自定义方法的排序
在Python中,排序是一个常见的任务,它可以帮助我们根据特定的规则对数据结构(如列表)中的元素进行排序。Python的内置排序方法,如列表的sort()函数和内置函数sorted(),提供了非常灵活的排序机制,特别是通过key参数,我们可以指定一个自定义的函数来决定排序的顺序。本文将探讨如何在Python中使用自定义方法来实现排序。
一、基础概念
在Python中,sort()方法会就地修改列表,使其元素按照指定的规则进行排序,而sorted()函数则会返回一个新的列表,原列表保持不变。两者都接受一个可选的key参数,该参数应该是一个函数,用于从每个元素中提取一个用于比较的关键字。
二、自定义排序方法
自定义排序方法通常是通过定义一个函数来实现的,该函数接受列表中的一个元素作为输入,并返回用于排序的关键字。这个关键字可以是元素的一个属性、一个计算结果,或者是对元素进行某种转换后的结果。
示例1:按字典中某个键的值排序
假设我们有一个字典列表,每个字典代表一个人的信息,包含姓名和年龄。我们想要根据年龄对这些人进行排序。
people = [
{'name': 'Alice', 'age': 30},
{'name': 'Bob', 'age': 25},
{'name': 'Charlie', 'age': 35}
]
# 使用sorted函数和自定义key
sorted_people = sorted(people, key=lambda x: x['age'])
print(sorted_people)
# 输出: [{'name': 'Bob', 'age': 25}, {'name': 'Alice', 'age': 30}, {'name': 'Charlie', 'age': 35}]
在这个例子中,我们使用了一个lambda函数作为key参数,该函数从字典中提取age键的值作为排序的关键字。
示例2:按字典中某几个键的总值排序
如果我们有一个自定义的类,并且想要根据类的某个属性对类的实例列表进行排序,我们也可以定义一个自定义的排序方法。
students = [
{'name': 'Alice', 'python': 30, 'java': 20, "html": 23},
{'name': 'Bob', 'python': 56, 'java': 32, "html": 21},
{'name': 'Charlie', 'python': 78, 'java': 34, "html": 43}
]
# 使用sorted函数和自定义key
sorted_students = sorted(students, key=lambda x: x['python']+x['java']+x['html'])
for i in sorted_students:
print(i)
# 输出:
# {'name': 'Alice', 'python': 30, 'java': 20, 'html': 23}
# {'name': 'Bob', 'python': 56, 'java': 32, 'html': 21}
# {'name': 'Charlie', 'python': 78, 'java': 34, 'html': 43}
在这个例子中,我们使用了一个lambda函数作为key参数,该函数从字典中提取python、java、html键的值作为排序的关键字。
三、高级排序
除了基于单个关键字的排序外,Python还允许我们进行更复杂的排序,比如先按一个关键字排序,如果第一个关键字相同,则按第二个关键字排序,依此类推。这可以通过嵌套使用tuple作为key函数的返回值来实现。
示例3:多条件排序
people = [
{'name': 'Charlie', 'age': 25},
{'name': 'Alice', 'age': 25},
{'name': 'Bob', 'age': 25},
]
# 假设我们想要先按年龄排序,如果年龄相同,则按姓名排序
sorted_people = sorted(people, key=lambda x: (x['age'], x['name']))
print(sorted_people)
# 输出: [{'name': 'Alice', 'age': 25}, {'name': 'Bob', 'age': 25}, {'name': 'Charlie', 'age': 25}]
Python基于自定义方法的排序的更多相关文章
- Python基于比较的排序
排序是算法学习中最基本的问题. 1.平均时间复杂度均为O(N2)的排序 1.1 插入排序 插入排序对少量元素的排序非常有效.工作机制就像打牌一样,为了将牌插入到已排好序的牌中,需要将牌与手中的牌从右向 ...
- 漫谈python中的搜索/排序
在数据结构那一块,搜索有顺序查找/二分查找/hash查找,而排序有冒泡排序/选择排序/插入排序/归并排序/快速排序.如果遇到数据量和数组排列方式不同,基于时间复杂度的考虑,可能需要用到混合算法.如果用 ...
- [python学习] 语言基础—排序函数(sort()、sorted()、argsort()函数)
python的内建排序函数有 sort.sorted两个. 1.基础的序列升序排序直接调用sorted()方法即可 ls = list([5, 2, 3, 1, 4]) new_ls = sorted ...
- Python list列表的排序
当我们从数据库中获取一写数据后,一般对于列表的排序是经常会遇到的问题,今天总结一下python对于列表list排序的常用方法: 第一种:内建函数sort() 这个应该是我们使用最多的也是最简单的排序函 ...
- python基于LeanCloud的短信验证
python基于LeanCloud的短信验证 1. 获取LeanCloud的Id.Key 2. 安装Flask框架和Requests库 pip install flask pip install re ...
- Python基于共现提取《釜山行》人物关系
Python基于共现提取<釜山行>人物关系 一.课程介绍 1. 内容简介 <釜山行>是一部丧尸灾难片,其人物少.关系简单,非常适合我们学习文本处理.这个项目将介绍共现在关系中的 ...
- Python 基于Python实现的ssh兼sftp客户端(上)
基于Python实现的ssh兼sftp客户端 by:授客 QQ:1033553122 实现功能 实现ssh客户端兼ftp客户端:实现远程连接,执行linux命令,上传下载文件 测试环境 Win7 ...
- 给定一个数组,求如果排序之后,相邻两数的最大差值,要求时间复杂度为O(N),且要求不能用非基于比较的排序
题目: 给定一个数组,求如果排序之后,相邻两数的最大差值,要求时间复杂度为O(N),且要求不能用非基于比较的排序 public static int maxGap(int nums[]) { if ( ...
- Python字典按值排序的方法
Python字典按值排序的方法: 法1: (默认升序排序,加 reverse = True 指定为降序排序) # sorted的结果是一个list dic1SortList = sorted( di ...
- solr特点三: 基于Solr实现排序定制化参考
排序实现有N种形式,最低成本.最快响应时间是目标 一份索引,支持N种排序策略并且在线互不干扰是要考虑的每一种实现,处理的场景是不同的,不要千篇一律 020排序,从索引到效果,有不少坑,这篇文章没有细说 ...
随机推荐
- python爬虫 正则表达式详解
正则表达式 最近学校布置了一个关于python爬虫的期末作业,而我之前对python爬虫一直都比较感兴趣但是没有系统的学过,就想借此机会开个新坑来系统学习和应用python爬虫,那我们开始吧 正则表达 ...
- vue 适配不同分辨率显示问题
新建 js 文件 rem.js class DevicePixelRatio { constructor() { // this.flag = false; } // 获取系统类型 _getSyste ...
- vue自定义事件及应用场景
自定义事件 <fuzujian :shijianming='fangfa'></fuzujian>//fangfa是父组件的方法 接收使用:props:[shijianming ...
- Flex 弹性布局备忘录
概述 Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性 这也是我目前用的最多的一种布局方案,相比Grid布局此种布局方案相对较简单, ...
- Qt在linux下实现程序编译后版本号自增的脚本
#! /bin/bash rm -rf temp.cpp num=0 while read line do if [ $num -eq 3 ];then array=(`echo $line | tr ...
- 【Amadeus原创】修改docker里面网站的port端口映射
切记:以下顺序千万不能颠倒!否则不生效! 1. 查看需要修改的容器,记住container id docker ps -a 2. 停止容器 docker stop xxx 3. 修改容器的端口映射配置 ...
- win10 ocx控件注册失败的解决办法
首先注意:ocx放在大部分系统目录无法注册,比如program file ,但windows目录可以. 第一步:关闭防火墙 第二步:确定是否缺少控件运行需要的微软运行库或其他运行环境 这里提供一个挺全 ...
- Qt编译数据库插件通用步骤说明
近期特意花了点时间,在之前数据库集成应用这个组件的基础上再次迭代完善,历经九九八十一难,将Qt的各种数据库插件,十几个Qt版本,全部编译一遍,同时打通了插件形式直连数据库和ODBC数据源连接方式,做过 ...
- Android-studio-ide-201.7042882-windows-4.1.2项目卡在Gradle: Download gradle-6.5-bin.zip
现象描述: Android-studio-ide-201.7042882-windows-4.1.2项目卡在Gradle: Download gradle-6.5-bin.zip,如下所示: 原因分析 ...
- 【狂神说Java】Java零基础学习笔记-预科
[狂神说Java]Java零基础学习笔记-预科 预科01:学习准备:博客 博客,英文名为Blog,它的正式名称为网络日记 为什么要写博客? 需要总结和思考.有时候我们一直在赶路,却忘了放慢脚步 提升文 ...