自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一日一技:包含元組的列表,對(duì)第一個(gè)元素升序第二個(gè)元素降序

開(kāi)發(fā) 前端
Python中的元組是可以比較大小的。它的比較方法就是先對(duì)第一個(gè)元素比較,如果第一個(gè)元素相等,再比較第二個(gè)元素。

大家都知道,在Python里面可以使用??.sort???方法或者??sorted??函數(shù)對(duì)各種數(shù)據(jù)進(jìn)行排序,例如:

a = [2, 3, 1, 9, 3, 7, 4]
a.sort()
b = [2, 3, 1, 9, 3, 7, 4]
c = sorted(b, reverse=True)

運(yùn)行效果如下圖所示:

圖片

我們也知道,Python中的元組是可以比較大小的。它的比較方法就是先對(duì)第一個(gè)元素比較,如果第一個(gè)元素相等,再比較第二個(gè)元素。因此對(duì)包含元組的列表也可以這樣排序,例如:

d = [(6, 5), (1, 3), (4, 7), (6, 4), (1, 8), (7, 9)]
d.sort()

圖片

但現(xiàn)在問(wèn)題來(lái)了,如果要對(duì)這個(gè)列表排序,但是需要對(duì)元組中的第一個(gè)元素升序,第二個(gè)元素降序,應(yīng)該怎么辦呢?

之前有一個(gè)很簡(jiǎn)單的算法題:輸入一串字符串,輸出出現(xiàn)次數(shù)最高的3個(gè)字母:

s = 'asgaurghajsfa;oeiwfasdfasdgrwerw'
count = {}
for letter in s:
count.setdefault(letter, 0)
count[letter] += 1

result = sorted(count.items(), key=lambda x: x[1], reverse=True)
print('出現(xiàn)頻率最高的3個(gè)字母分別是:', result[:3])

運(yùn)行效果如下圖所示:

圖片

如果你做過(guò)這個(gè)算法題,那么你肯定知道怎么做。只需要設(shè)置??key??參數(shù)就可以了。在第二個(gè)元素前面加個(gè)負(fù)號(hào):

d = [(6, 5), (1, 3), (4, 7), (6, 4), (1, 8), (7, 9)]
e = sorted(d, key=lambda x: (x[0], -x[1]))

運(yùn)行效果如下圖所示:

圖片

現(xiàn)在問(wèn)題來(lái)了,如果被排序的列表里面的元組第二項(xiàng),不是數(shù)字,而是字符串怎么辦?字符串前面又不能加負(fù)號(hào)啊。

例如對(duì)如下列表進(jìn)行排序,按元組第一個(gè)元素升序,第二個(gè)元素降序:

[(6, 'apple'), (1, 'google'), (4, 'future'), (6, 'zero'), (1, 'stand'), (7, 't')]

可能有同學(xué)會(huì)想到,可以把字符轉(zhuǎn)成Ascii碼再來(lái)加負(fù)號(hào)。這個(gè)方法對(duì)單個(gè)字符確實(shí)可行,但是當(dāng)字符串有多個(gè)字符時(shí),這樣做就顯得很麻煩了。

為了解決這個(gè)問(wèn)題,我們需要回想一下,為什么在Python里面,有一些對(duì)象可以比大小,另一些對(duì)象卻不行?為什么字符串可以比大小,數(shù)字可以比大小,但是當(dāng)我自定義一個(gè)類(lèi),然后生成對(duì)象的時(shí)候,卻不能比大小?

圖片

Python里面能比較大小的對(duì)象,是因?yàn)樗麄兊念?lèi)里面有一類(lèi)特殊的魔術(shù)方法:??__eq__??用來(lái)判斷是否相等,??__lt__??用來(lái)判斷是否小于,??__gt__??來(lái)判斷是否大于……,例如:

圖片

這樣一來(lái),如果想要倒序,只需要把??__lt__??里面的邏輯反過(guò)來(lái)就可以了:

圖片

我們?cè)賮?lái)寫(xiě)一下排序函數(shù),對(duì)于需要倒序的位置使用這個(gè)自定義的類(lèi)包一下:

class Reversor:
def __init__(self, value):
self.value = value

def __eq__(self, other):
return self.value == other.value

def __lt__(self, other):
return other.value < self.value


d = [(6, 5), (1, 3), (4, 7), (6, 4), (1, 8), (7, 9)]
e = sorted(d, key=lambda x: (x[0], Reversor(x[1])))

運(yùn)行效果如下圖所示:

圖片

并且,這個(gè)類(lèi)對(duì)字符串排序依然適用:

圖片

責(zé)任編輯:武曉燕 來(lái)源: 未聞Code
相關(guān)推薦

2022-03-07 09:14:04

Selenium鼠標(biāo)元素

2021-10-15 21:08:31

PandasExcel對(duì)象

2020-12-04 06:39:25

爬蟲(chóng)網(wǎng)頁(yè)

2024-07-30 08:11:16

2022-02-06 10:43:43

PDF文件Python

2021-04-27 22:15:02

Selenium瀏覽器爬蟲(chóng)

2021-10-06 23:17:26

Python抽象類(lèi)接口

2021-08-13 07:56:13

MongoDBScrapy元素

2024-09-05 12:11:25

大模型抓取列表頁(yè)

2021-04-12 21:19:01

PythonMakefile項(xiàng)目

2023-09-06 00:15:04

Pandas技巧格式

2022-06-28 09:31:44

LinuxmacOS系統(tǒng)

2021-04-05 14:47:55

Python多線程事件監(jiān)控

2024-11-13 09:18:09

2022-03-12 20:38:14

網(wǎng)頁(yè)Python測(cè)試

2021-02-14 22:22:18

格式圖片 HTTP

2024-04-08 00:00:02

setup技巧Pypi

2024-03-18 09:50:18

Selenium元素Python

2024-11-11 00:38:13

Mypy靜態(tài)類(lèi)型

2021-07-27 21:32:57

Python 延遲調(diào)用
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)