加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – 有没有办法在使用operator.itemgetter()作为排序键时

发布时间:2020-12-20 11:59:00 所属栏目:Python 来源:网络整理
导读:我有一个包含字符串代表数字的列表列表: nums = [['1','3'],['2','2'],['1',['0',['11','2']] 我需要通过第一个和第二个条目对这些数字进行排序,而不修改原始列表中数字的字符串表示.此外,想要避免创建另一个列表的第二个副本,其中所有内容都明确映射到整数
我有一个包含字符串代表数字的列表列表:

nums = [['1','3'],['2','2'],['1',['0',['11','2']]

我需要通过第一个和第二个条目对这些数字进行排序,而不修改原始列表中数字的字符串表示.此外,想要避免创建另一个列表的第二个副本,其中所有内容都明确映射到整数 – 想象这是一个巨大的列表.

sort()和sorted()都可以很好地处理元组和列表,所以使用lambda键,我可以执行以下操作:

>>> sorted(nums,key=lambda n: (int(n[0]),int(n[1])) 
[['0','2']]

快乐的时光…

但是,我已经看到一些关于使用operator.itemgetter()作为使用lambda的关键函数进行排序更快的帖子.在没有讨论这些声明的有效性的情况下,如果有可能在使用operator.itemgetter()时应用从字符串转换为整数进行比较的任何人:

由于字符串被比较为字符串而不是数字,以下显然会失败:

>>> sorted(nums,key=operator.itemgetter(0,1)) 
[['0','2']]

解决方法

有方法,例如使用 iteration_utilities.chained 1和 functools.partial

>>> import operator import itemgetter
>>> from iteration_utilities import chained
>>> from functools import partial

>>> itemgetter_int = chained(operator.itemgetter(0,1),partial(map,int),tuple)
>>> sorted(nums,key=itemgetter_int)
[['0','2']]

它可以工作,但它比使用lambda或自定义函数要慢得多.

如果你真的需要速度,你可以对lambda函数进行cython化(或者用C语言编写),但是如果你只需要在一个地方使用它就可以使用丢弃的lambda.特别是如果它处于排序状态,因为它具有O(nlog(n))比较,因此O(n)函数调用可能对总体执行时间没有太大贡献.

1:这是我创作的3rd party extension module中的一个功能.它需要单独安装,例如通过conda或pip.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读