Python3 自定义排序详解:方法与示例

简介: Python的排序功能强大且灵活,主要通过`sorted()`函数和列表的`sort()`方法实现。两者均支持`key`参数自定义排序规则。本文详细介绍了基础排序、按字符串长度或元组元素排序、降序排序、多条件排序及使用`lambda`表达式和`functools.cmp_to_key`进行复杂排序。通过示例展示了如何对简单数据类型、字典、类对象及复杂数据结构(如列车信息)进行排序。掌握这些技巧可以显著提升数据处理能力,为编程提供更强大的支持。

在Python编程中,排序是一项常见的操作。Python提供了强大的排序功能,通过sorted()函数和列表的sort()方法,可以方便地对列表进行排序。这两个方法都支持key参数,允许开发者自定义排序规则。本文将通过详细的方法和示例,讲解如何在Python3中实现自定义排序。
站大爷代理IP工具的验证功能介绍 (31).png

一、基础排序
Python的sorted()函数返回一个新的列表,而列表的sort()方法则直接对原列表进行排序,不返回任何值(返回值为None)。

基础示例

numbers = [5, 2, 9, 1, 5, 6]
sorted_numbers = sorted(numbers)
print(sorted_numbers) # 输出: [1, 2, 5, 5, 6, 9]
使用sort()方法:

python
numbers = [5, 2, 9, 1, 5, 6]
numbers.sort()
print(numbers) # 输出: [1, 2, 5, 5, 6, 9]

二、自定义排序规则
通过key参数,可以自定义排序规则。key参数接收一个函数,该函数会接收列表中的每一个元素作为参数,并返回一个值作为该元素的排序优先级。

2.1 按字符串长度排序

words = ["apple", "banana", "cherry", "date"]
sorted_words = sorted(words, key=len)
print(sorted_words) # 输出: ['date', 'apple', 'banana', 'cherry']

2.2 按元组的第二个元素排序

pairs = [(1, 3), (4, 1), (2, 5), (3, 2)]
sorted_pairs = sorted(pairs, key=lambda x: x[1])
print(sorted_pairs) # 输出: [(4, 1), (3, 2), (1, 3), (2, 5)]

2.3 降序排序
通过reverse=True参数,可以实现降序排序。

numbers = [5, 2, 9, 1, 5, 6]
sorted_numbers_desc = sorted(numbers, reverse=True)
print(sorted_numbers_desc) # 输出: [9, 6, 5, 5, 2, 1]

使用sort()方法时也可以指定reverse=True:

numbers = [5, 2, 9, 1, 5, 6]
numbers.sort(reverse=True)
print(numbers) # 输出: [9, 6, 5, 5, 2, 1]

2.4 多条件排序
有时需要根据多个条件进行排序,例如先按一个字段排序,再按另一个字段排序。

people = [('Alice', 25), ('Bob', 30), ('Alice', 22)]
sorted_people = sorted(people, key=lambda x: (x[0], x[1]))
print(sorted_people) # 输出: [('Alice', 22), ('Alice', 25), ('Bob', 30)]

三、使用lambda表达式定义复杂排序规则
lambda表达式可以用于定义更复杂的排序规则。

3.1 按字典值排序

people = {"Alice": 30, "Bob": 25, "Charlie": 35}
sorted_people = sorted(people.items(), key=lambda x: x[1])
print(sorted_people) # 输出: [('Bob', 25), ('Alice', 30), ('Charlie', 35)]

3.2 对类对象排序

可以创建一个类,并根据类的属性对对象进行排序。

class Person:
def init(self, name, age):
self.name = name
self.age = age

def __repr__(self):
    return f"Person{name=self.name, age=self.age}"

创建Person对象

people = [Person("Alice", 30), Person("Bob", 25), Person("Charlie", 35)]

按年龄排序

sorted_people = sorted(people, key=lambda person: person.age)
for person in sorted_people:
print(person)

输出: Person{name='Bob', age=25}, Person{name='Alice', age=30}, Person{name='Charlie', age=35}

四、使用functools.cmp_to_key进行传统比较
当需要使用传统的比较函数(cmp函数)时,可以使用functools.cmp_to_key进行转换。

from functools import cmp_to_key

自定义比较函数

def compare(a, b):
if a % 2 == b % 2:
return a - b # 相同类型(奇偶性)按大小排序
return -1 if a % 2 == 0 else 1 # 偶数优先

numbers = [1, 2, 3, 4, 5, 6, 7, 8]
sorted_numbers = sorted(numbers, key=cmp_to_key(compare))
print(sorted_numbers) # 输出: [2, 4, 6, 8, 1, 3, 5, 7]

五、复杂数据结构排序示例
假设有一个包含列车信息的列表,需要根据“二等座”是否有票以及“历时”进行排序。

tickets = [
{'车次': 'G1', '历时': "1:23", '二等座': "有"},
{'车次': 'G2', '历时': "1:00", '二等座': "有"},
{'车次': 'G3', '历时': "0:23", '二等座': "13"},
{'车次': 'G4', '历时': "1:55", '二等座': "44"},
{'车次': 'G5', '历时': "0:21", '二等座': "13"},
{'车次': 'G6', '历时': "1:55", '二等座': "44"}
]

定义比较函数

def cmp_seat(t1, t2):
if t1["二等座"] == "有":
if t2["二等座"] == "有":
return 0
else:
return -1
else:
if t2["二等座"] == "有":
return 1
else:
return int(t2["二等座"]) - int(t1["二等座"])

def cmp_time(t1, t2):
hs1 = t1["历时"].split(":")
hs2 = t2["历时"].split(":")
tm1 = int(hs1[0]) 60 + int(hs1[1])
tm2 = int(hs2[0])
60 + int(hs2[1])
return tm1 - tm2

def cmp(t1, t2):
if cmp_seat(t1, t2) != 0:
return cmp_seat(t1, t2)
else:
return cmp_time(t1, t2)

使用cmp_to_key进行排序

tickets.sort(key=cmp_to_key(cmp))
for ticket in tickets:
print(ticket)

在这个例子中,cmp_seat函数用于比较“二等座”是否有票,cmp_time函数用于比较“历时”,cmp函数则综合这两个条件进行比较。最终通过tickets.sort(key=cmp_to_key(cmp))实现排序。

六、总结
Python的自定义排序功能非常强大,通过key参数和functools.cmp_to_key,可以灵活地定义排序规则。无论是简单的数据类型(如整数和字符串),还是复杂的对象,都可以轻松实现自定义排序。掌握自定义排序,可以大大增强对数据的处理能力,为数据分析和处理提供更强大的支持。

通过本文的示例,希望读者能够深刻理解Python自定义排序的用法,并在实际编程中灵活运用。自定义排序不仅限于上述示例,开发者可以根据实际需求,设计出更加复杂和高效的排序规则。

目录
相关文章
|
1月前
|
Java 数据处理 索引
(Pandas)Python做数据处理必选框架之一!(二):附带案例分析;刨析DataFrame结构和其属性;学会访问具体元素;判断元素是否存在;元素求和、求标准值、方差、去重、删除、排序...
DataFrame结构 每一列都属于Series类型,不同列之间数据类型可以不一样,但同一列的值类型必须一致。 DataFrame拥有一个总的 idx记录列,该列记录了每一行的索引 在DataFrame中,若列之间的元素个数不匹配,且使用Series填充时,在DataFrame里空值会显示为NaN;当列之间元素个数不匹配,并且不使用Series填充,会报错。在指定了index 属性显示情况下,会按照index的位置进行排序,默认是 [0,1,2,3,...] 从0索引开始正序排序行。
196 0
|
2月前
|
人工智能 数据安全/隐私保护 异构计算
桌面版exe安装和Python命令行安装2种方法详细讲解图片去水印AI源码私有化部署Lama-Cleaner安装使用方法-优雅草卓伊凡
桌面版exe安装和Python命令行安装2种方法详细讲解图片去水印AI源码私有化部署Lama-Cleaner安装使用方法-优雅草卓伊凡
351 8
桌面版exe安装和Python命令行安装2种方法详细讲解图片去水印AI源码私有化部署Lama-Cleaner安装使用方法-优雅草卓伊凡
|
2月前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
281 1
|
2月前
|
算法 调度 决策智能
【两阶段鲁棒优化】利用列-约束生成方法求解两阶段鲁棒优化问题(Python代码实现)
【两阶段鲁棒优化】利用列-约束生成方法求解两阶段鲁棒优化问题(Python代码实现)
|
2月前
|
缓存 监控 供应链
唯品会自定义 API 自定义操作深度分析及 Python 实现
唯品会开放平台提供丰富API,支持商品查询、订单管理、促销活动等电商全流程操作。基于OAuth 2.0认证机制,具备安全稳定的特点。通过组合调用基础接口,可实现数据聚合、流程自动化、监控预警及跨平台集成,广泛应用于供应链管理、数据分析和智能采购等领域。结合Python实现方案,可高效完成商品搜索、订单分析、库存监控等功能,提升电商运营效率。
|
2月前
|
缓存 监控 供应链
京东自定义 API 操作深度分析及 Python 实现
京东开放平台提供丰富API接口,支持商品、订单、库存等电商全链路场景。通过自定义API组合调用,可实现店铺管理、数据分析、竞品监控等功能,提升运营效率。本文详解其架构、Python实现与应用策略。
缓存 监控 供应链
62 0
缓存 监控 数据挖掘
50 0
|
3月前
|
机器学习/深度学习 数据采集 TensorFlow
基于CNN-GRU-Attention混合神经网络的负荷预测方法(Python代码实现)
基于CNN-GRU-Attention混合神经网络的负荷预测方法(Python代码实现)
128 0
|
3月前
|
机器学习/深度学习 数据采集 数据挖掘
基于 GARCH -LSTM 模型的混合方法进行时间序列预测研究(Python代码实现)
基于 GARCH -LSTM 模型的混合方法进行时间序列预测研究(Python代码实现)
111 2

推荐镜像

更多