Python列表使用sort方法时不能使用key=self.index方法的问题探究

在使用python对列表排序的时候,突然发现了一个有意思的现象。对列表a,在使用a.sort()方法进行排序时,使用key参数,不能使用自己的方法,比如a.index等方法

使用失败的示例

代码目标是对列表以其元素第一次出现的顺序进行排序。

此时会引发一个ValueError,提示在排序时第一个元素不在列表内。

这里看不出什么情况,需要自己实现下index方法来处理

模拟index方法

定义find_index函数,使用functools中的partial方法定义偏函数来实现index方法

在14行调用偏函数时,可以发现我们在其中显示的是列表和其元素参数,但在17行进行调用时,列表变成了空列表。

如果我们在其中使用id方法来检测列表的id时,会发现从始至终,这个列表的id是没有变的。说明在使用sort()方法排序的时候,列表会先变成空列表再往里排东西。

此处实现经过查询资料,发现是在源码中有体现

cpython/Objects/listobject.c at main · python/cpython · GitHub

在使用sort方法进行排序的时候,列表会先置为空的,所以原有列表打印的时候是个空列表,使用原有列表的index方法来排序就会失败。

如果我们确实需要实现这个排序,可以借助sorted函数来使用一个拷贝实现。

此时不会报错,得到的效果也是预期的排序方式。

在算法层面,我们自己写的排序不太可能比内置的sort快,内置的sort是用的底层c语言写的,怎么用python重复造轮子也很难超越,不必去钻此类牛角尖。

而sort和sorted相比,因为少了副本拷贝,速度上会比sorted快一些,但像上面的场景,我们就需要考虑舍弃这点性能了。 希望这篇文章能对大家有所帮助!

相关推荐
Doris_202319 分钟前
Python条件判断语句 if、elif 、else
前端·后端·python
Doris_202324 分钟前
Python 模式匹配match case
前端·后端·python
这里有鱼汤1 小时前
Python量化实盘踩坑指南:分钟K线没处理好,小心直接亏钱!
后端·python·程序员
大模型真好玩1 小时前
深入浅出LangGraph AI Agent智能体开发教程(五)—LangGraph 数据分析助手智能体项目实战
人工智能·python·mcp
测试老哥2 小时前
Selenium 使用指南
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
百锦再2 小时前
[特殊字符] Python在CentOS系统执行深度指南
开发语言·python·plotly·django·centos·virtualenv·pygame
张子夜 iiii2 小时前
4步OpenCV-----扫秒身份证号
人工智能·python·opencv·计算机视觉
潮汐退涨月冷风霜3 小时前
数字图像处理(1)OpenCV C++ & Opencv Python显示图像和视频
c++·python·opencv
酷飞飞9 小时前
Python网络与多任务编程:TCP/UDP实战指南
网络·python·tcp/ip
数字化顾问11 小时前
Python:OpenCV 教程——从传统视觉到深度学习:YOLOv8 与 OpenCV DNN 模块协同实现工业缺陷检测
python