av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Python列表排序 list.sort方法和內(nèi)置函數(shù)sorted用法

瀏覽:3日期:2022-06-25 08:18:51

很多時(shí)候我們獲取到一個(gè)列表后,這個(gè)列表并不滿足我們的需求,我們需要的是一個(gè)有特殊順序的列表.

這時(shí)候就可以使用list.sort方法和內(nèi)置函數(shù)sorted,本文就是介紹list.sort方法和sorted內(nèi)置函數(shù)的使用方法和區(qū)別.

一、list.sort方法

list.sort方法會(huì)就地排序列表,也就是說(shuō)不會(huì)把原列表復(fù)制一份。這也是這個(gè)方法的返回值是None的原因,提醒您本方法不會(huì)新建一個(gè)列表。

在這種情況下返回None其實(shí)是Python的一個(gè)慣例:如果一個(gè)函數(shù)或者方法對(duì)對(duì)象進(jìn)行的是就地改動(dòng),那它就應(yīng)該返回 None,好讓調(diào)用者知道傳入的參數(shù)發(fā)生了變動(dòng),而且并未產(chǎn)生新的對(duì)象。

來(lái)看一下代碼:

# coding=utf-8list_a = [1, 2, 8, 3, 7, 9, 5, 7]# sort()方法沒(méi)有返回值list_b = list_a.sort()print('list_a: ', list_a)print(’list_b: ’, list_b)

運(yùn)行結(jié)果:

list_a: [1, 2, 3, 5, 7, 7, 8, 9]list_b: None

用返回None來(lái)表示就地改動(dòng)這個(gè)慣例有個(gè)弊端,那就是調(diào)用者無(wú)法將其串聯(lián)起來(lái)。而返回一個(gè)新對(duì)象的方法則正好相反,它們可以鏈?zhǔn)秸{(diào)用,從而形成連貫接口。

二、sorted內(nèi)置函數(shù)

與 list.sort 相反,內(nèi)置函數(shù)sorted會(huì)新建一個(gè)列表作為返回值。

這個(gè)方法可以接受任何形式的可迭代對(duì)象作為參數(shù),甚至包括不可變序列或生成器,而不管sorted接受的是怎樣的參數(shù),它最后都會(huì)返回一個(gè)列表。

代碼示例:

list_c = [1, 2, 8, 3, 7, 9, 5, 7]# sorted內(nèi)置函數(shù)會(huì)返回一個(gè)排序后的新列表list_d = sorted(list_c)print('list_c: ', list_c)print(’list_d: ’, list_d)

運(yùn)行結(jié)果:

list_c: [1, 2, 8, 3, 7, 9, 5, 7]list_d: [1, 2, 3, 5, 7, 7, 8, 9]

可以看到,使用內(nèi)置函數(shù)sorted時(shí),返回了一個(gè)新的列表,而原列表沒(méi)有發(fā)生改變。

這有兩種好處:

1.如果我們即需要使用原列表,也需要使用排序后的列表,或者說(shuō)我們要將一個(gè)非列表的可迭代對(duì)象排序成列表,sorted都可以做到

2.有返回值時(shí),我們可以進(jìn)行鏈?zhǔn)秸{(diào)用

# 可以對(duì)非列表的可迭代對(duì)象排序生成列表str_e = ’python’list_e = sorted(str_e)print(list_e) # 鏈?zhǔn)秸{(diào)用str_f = ’-’.join(sorted(str_e)).upper().split(’-’)print(str_f)

運(yùn)行結(jié)果:

[’h’, ’n’, ’o’, ’p’, ’t’, ’y’][’H’, ’N’, ’O’, ’P’, ’T’, ’Y’]三、關(guān)鍵字參數(shù)key和reverse

不管是 list.sort 方法還是 sorted 函數(shù),都有兩個(gè)可選的關(guān)鍵字參數(shù):

key:

接收一個(gè)只有一個(gè)參數(shù)的函數(shù),這個(gè)函數(shù)會(huì)被用在序列里的每一個(gè)元素上,所產(chǎn)生的結(jié)果將是排序算法依賴的對(duì)比關(guān)鍵字。

比如說(shuō),在對(duì)一些字符串排序時(shí),可以用 key=str.lower 來(lái)實(shí)現(xiàn)忽略大小寫(xiě)的排序,或者是用 key=len 進(jìn)行基于字符串長(zhǎng)度的排序。key的默認(rèn)值是恒等函數(shù),也就是默認(rèn)用元素自己的值來(lái)排序。

reverse:

如果被設(shè)定為 True,被排序的序列里的元素會(huì)以降序輸出(也就是說(shuō)把最大值當(dāng)作最小值來(lái)排序),reverse的默認(rèn)值是 False.

phone = (’HUAWEI’, ’OPPO’, ’MI’, ’MEIZU’, ’VIVO’)# 按長(zhǎng)度進(jìn)行排序phone_list = sorted(phone, key=len)print(phone_list) phone_list_re = sorted(phone, key=len, reverse=True)print(phone_list_re)

運(yùn)行結(jié)果:

[’MI’, ’OPPO’, ’VIVO’, ’MEIZU’, ’HUAWEI’][’HUAWEI’, ’MEIZU’, ’OPPO’, ’VIVO’, ’MI’]

上面的代碼中,第一次排序新建了一個(gè)按照長(zhǎng)度排序的字符串列表。第二次排序是將按長(zhǎng)度排序由升序變成了降序。

細(xì)心的您應(yīng)該可以發(fā)現(xiàn),第二次的結(jié)果并不是第一次排序的結(jié)果的完全翻轉(zhuǎn)。

OPPO和VIVO的長(zhǎng)度都是4,reverse=True后,它們的相對(duì)位置跟第一次排序是一樣的。這是什么原因呢?

sorted和list.sort背后的排序算法都是Timsort,它是一種自適應(yīng)算法,會(huì)根據(jù)原始數(shù)據(jù)的順序特點(diǎn)交替使用插入排序和歸并排序,以達(dá)到最佳效率。

Python的排序算法Timsort是穩(wěn)定的(知道這一點(diǎn)就可以了),意思是就算兩個(gè)元素比不出大小,在每次排序的結(jié)果里它們的相對(duì)位置是固定的。

因?yàn)橛玫降呐判蛩惴ㄊ欠€(wěn)定的,也就是說(shuō)在長(zhǎng)度一樣時(shí),OPPO和VIVO的相對(duì)位置不會(huì)改變。

關(guān)于list.sort()方法和sorted內(nèi)置函數(shù)的使用,現(xiàn)在已經(jīng)掌握了~

補(bǔ)充:python知識(shí)點(diǎn),列表排序sort()和sorted()的區(qū)別?

sort()是列表類型的方法,只適用于列表;sorted()是內(nèi)置函數(shù),支持各種容器類型。它們都可以排序,且用法類似,但sort()是在原地排序的,不會(huì)返回排序后的列表,而sorted()是返回新的排序列表。

>>> help(list.sort)Help on method_descriptor:sort(...) L.sort(key=None, reverse=False) -> None -- stable sort *IN PLACE*>>> help(sorted)Help on built-in function sorted in module builtins:sorted(iterable, /, *, key=None, reverse=False) Return a new list containing all items from the iterable in ascending order. A custom key function can be supplied to customize the sort order, and the reverse flag can be set to request the result in descending order.本文僅簡(jiǎn)單介紹排序用法。

例如列表L:

>>> L = [’python’, ’shell’, ’Perl’, ’Go’, ’PHP’]

使用sort()和sorted()排序L,注意sort()是對(duì)L直接原地排序的,不是通過(guò)返回值來(lái)體現(xiàn)排序結(jié)果的,所以無(wú)需賦值給變量。而sorted()則是返回排序后的新結(jié)果,需要賦值給變量才能保存排序結(jié)果。

>>> sorted(L)[’Go’, ’PHP’, ’Perl’, ’python’, ’shell’]>>> L[’python’, ’shell’, ’Perl’, ’Go’, ’PHP’]>>> L.sort()>>> L[’Go’, ’PHP’, ’Perl’, ’python’, ’shell’]

不難發(fā)現(xiàn),sort()和sorted()默認(rèn)都是升序排序的(A<B<...<Z<a<b<...<z)。它們都可以指定參數(shù)reverse=True來(lái)表示順序反轉(zhuǎn),也就是默認(rèn)得到降序:

>>> L.sort(reverse=True)>>> L[’shell’, ’python’, ’Perl’, ’PHP’, ’Go’]

在python 3.x中,sort()和sorted()不允許對(duì)包含不同數(shù)據(jù)類型的列表進(jìn)行排序。也就是說(shuō),如果列表中既有數(shù)值,又有字符串,則排序操作報(bào)錯(cuò)。

sort()和sorted()的另一個(gè)參數(shù)是key,它默認(rèn)為key=None,該參數(shù)用來(lái)指定自定義的排序函數(shù),從而實(shí)現(xiàn)自己需要的排序規(guī)則。

例如,上面的列表不再按照默認(rèn)的字符順序排序,而是想要按照字符串的長(zhǎng)度進(jìn)行排序。所以,自定義這個(gè)排序函數(shù):

>>> def sortByLen(s):... return len(s)

然后通過(guò)指定key = sortByLen的參數(shù)方式調(diào)用sort()或sorted(),在此期間還可以指定reverse = True:

>>> L = [’shell’, ’python’, ’Perl’, ’PHP’, ’Go’]>>> sorted(L,key=sortByLen)[’Go’, ’PHP’, ’Perl’, ’shell’, ’python’]5>>> L.sort(key=sortByLen,reverse=True)>>> L[’python’, ’shell’, ’Perl’, ’PHP’, ’Go’]

再例如,按照列表每個(gè)元素的第二個(gè)字符來(lái)排序。

def f(e): return e[1]L = [’shell’, ’python’, ’Perl’, ’PHP’, ’Go’]sorted(L, key=f)L.sort(key=f)

更多的排序方式,比如指定兩個(gè)排序依據(jù),一個(gè)按字符串長(zhǎng)度升序排,長(zhǎng)度相同的按第2個(gè)字符降序排。用法其實(shí)很簡(jiǎn)單,不過(guò)稍占篇幅,所以本文不解釋了。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 国产精品一区二区三区在线 | 99视频在线看 | 一区二区三区在线播放 | 久草成人| 日韩免费激情视频 | 国产精品免费高清 | 日韩久久久久 | 亚洲高清在线 | 国产精品一区二区久久 | 国产一区二区黑人欧美xxxx | 青青激情网 | 天天干天天操天天看 | 国产一区二区精品在线观看 | 久草在线影 | 精品视频在线观看 | 在线观看精品视频网站 | 中文在线www | 青青草在线视频免费观看 | 日韩在线欧美 | 欧美在线视频一区二区 | 国产一区2区 | 亚洲视频在线观看 | 亚州精品天堂中文字幕 | 亚洲日韩中文字幕一区 | 美日韩视频 | 亚洲影视在线 | 欧美理伦片在线播放 | 欧美国产日韩在线观看成人 | 国产伦精品一区二区三区精品视频 | 免费观看羞羞视频网站 | 九七午夜剧场福利写真 | 欧美日韩免费一区二区三区 | 国产91丝袜在线播放 | 国产做a爱免费视频 | 黄色一级大片在线免费看产 | 精品久草 | 小草久久久久久久久爱六 | 亚洲成人网在线 | 999精品视频 | 亚洲三级在线观看 | 亚洲国产一区二区三区 |