首页 > 编程知识 正文

python中sorted函数里的key,sorted函数的key

时间:2023-05-06 05:19:41 阅读:196980 作者:3155

python sorted & list.sort()

在python中,sorted和list.sort背后的算法是Timsort算法,它是一种自适应算法,会根据原始数据的顺序特点交替使用插入排序或者归并排序,已达到最佳效率。这样的算法被证明是很有效的,因为来自真实世界的数据通常是有一定的顺序特点的。Timsort在2002年的时候,首次用在CPython中。

key参数很妙

key参数是一个很棒的设计。能把事情变得简单高效。说它简单是因为只需要提供一个单参数函数来提取或者计算一个值作为比较大小的标准即可,在排序的时候,python会基于两个key,但是那一阶段的计算发生在C语言那一层,这样会比调用用户自定义的python比较函数更快。
因此用sorted函数效率更高。

用法举例

下面这个代码是对一副扑克牌进行排序。

import collectionsfrom random import choiceCard = collections.namedtuple('Card', ['rank', 'suit']) #定义类型card,有rank和card两种属性class FrenchDeck: ranks = [str(n) for n in range(2, 11)] + list('JQKA') suits = 'spades diamonds clubs hearts'.split() def __init__(self): self.cards = [Card(rank, suit) for suit in self.suits for rank in self.ranks] def __len__(self): return len(self.cards) def __getitem__(self, position): return self.cards[position]beer_card = Card('7', 'diamond')print(beer_card)french = FrenchDeck()print(french.cards)print(len(french))print(french[0])print(french[-1])print(choice(french))print(choice(french))#排序suit_valus = dict(spades = 3, hearts = 2, diamonds = 1, clubs = 0)def spades_high(card): #排序函数,定义key,使得从低到高排序 rank_value = french.ranks.index(card.rank) return rank_value * 4 + suit_valus[card.suit]for card in sorted(french, key=spades_high): print(card)

扑克牌有两个属性,一个是rank,一个是花色(suits)。
首先自己定义init方法来初始化扑克牌
然后自己定义len方法来计算扑克牌的长度
然后自己定义getitem方法来返回下标,这样可以最大情况下避免重造轮子

定义了排序函数spades_high,根据扑克牌的rank和suit来确定返回的key,然后使用sorted进行排序,返回一个python的迭代器。

从结果中可以看到,扑克牌顺序输出。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。