Python列表具有內(nèi)置的 list.sort()方法,可以在原地修改列表。 還有一個 sorted()內(nèi)置的函數(shù)從迭代構(gòu)建一個新的排序列表。在本文中,我們將探討使用Python排序數(shù)據(jù)的各種技術(shù)。
專注于為中小企業(yè)提供成都做網(wǎng)站、成都網(wǎng)站設(shè)計、成都外貿(mào)網(wǎng)站建設(shè)服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)花都免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
請注意,sort()原始數(shù)據(jù)被破壞,sorted()沒有對原始數(shù)據(jù)進(jìn)行操作,而是新建了一個新數(shù)據(jù)。
一、基本的排序
最基本的排序很簡單。只要使用sorted()函數(shù)即可返回一個 新的排序的列表
sorted([5, 2, 3, 1, 4])
[1, 2, 3, 4, 5]
咱們也可以使用 list.sort()方法。該方法是對列表list進(jìn)行的原地操作(原數(shù)據(jù)被修改,已經(jīng)不是原來的本來面目)。一般情況下,不如使用 sorted()方便,但是如果你不需要原列表list,使用 sort()會更具效率。
a = [5, 2, 3, 1, 4]
a.sort()
a #a發(fā)生改變
[1, 2, 3, 4, 5]
另一個不同點, list.sort()方法只能應(yīng)用于列表對象數(shù)據(jù)。而 sorted()卻可以對任何可迭代對象進(jìn)行排序。也就是說sorted()更具有普遍使用性。這里大燈建議初學(xué)者使用sorted()。
二、Key參數(shù)函數(shù)
list.sort()和 sorted()都有key參數(shù),可以指定函數(shù)來對元素進(jìn)行排序。
例如,這里我們使用一個字符串(字符串也是可迭代對象)
sorted("This is a test string from Andrew".split(), key=str.lower)
1、首先我們定義一個列表輸入一串大小不一的數(shù)字。
2、可以用sort()方法對定義的列表排序,注意,sort只是對列表排序,它沒有返回一個值。
3、輸入print列表名即可得到排序后的列表數(shù)據(jù)。
4、倒序可以用這個reverse方法,把元素位置倒轉(zhuǎn)過來。
5、然后再次print列表名,這樣就會得到倒轉(zhuǎn)順序之后的列表數(shù)據(jù)。
5、如圖兩相對比即實現(xiàn)了從高到低和從低到高排序。
進(jìn)行一個簡單的升序排列直接調(diào)用sorted()函數(shù),函數(shù)將會返回一個排序后的列表:
sorted函數(shù)不會改變原有的list,而是返回一個新的排好序的list
如果你想使用就地排序,也就是改變原list的內(nèi)容,那么可以使用list.sort()的方法,這個方法的返回值是None。
另一個區(qū)別是,list.sort()方法只是list也就是列表類型的方法,只可以在列表類型上調(diào)用。而sorted方法則是可以接受任何可迭代對象。
list.sort()和sorted()函數(shù)都有一個key參數(shù),可以用來指定一個函數(shù)來確定排序的一個優(yōu)先級。比如,這個例子就是根據(jù)大小寫的優(yōu)先級進(jìn)行排序:
key參數(shù)的值應(yīng)該是一個函數(shù),這個函數(shù)接受一個參數(shù)然后返回以一個key,這個key就被用作進(jìn)行排序。這個方法很高效,因為對于每一個輸入的記錄只需要調(diào)用一次key函數(shù)。
一個常用的場景就是當(dāng)我們需要對一個復(fù)雜對象的某些屬性進(jìn)行排序時:
再如:
前面我們看到的利用key-function來自定義排序,同時Python也可以通過operator庫來自定義排序,而且通常這種方法更好理解并且效率更高。
operator庫提供了 itemgetter(), attrgetter(), and a methodcaller()三個函數(shù)
同時還支持多層排序
list.sort()和sorted()都有一個boolean類型的reverse參數(shù),可以用來指定升序和降序排列,默認(rèn)為false,也就是升序排序,如果需要降序排列,則需將reverse參數(shù)指定為true。
排序的穩(wěn)定性指,有相同key值的多個記錄進(jìn)行排序之后,原始的前后關(guān)系保持不變
我們可以看到python中的排序是穩(wěn)定的。
我們可以利用這個穩(wěn)定的特性來進(jìn)行一些復(fù)雜的排序步驟,比如,我們將學(xué)生的數(shù)據(jù)先按成績降序然后年齡升序。當(dāng)排序是穩(wěn)定的時候,我們可以先將年齡升序,再將成績降序會得到相同的結(jié)果。
傳統(tǒng)的DSU(Decorate-Sort-Undecorate)的排序方法主要有三個步驟:
因為元組是按字典序比較的,比較完grade之后,會繼續(xù)比較i。
添加index的i值不是必須的,但是添加i值有以下好處:
現(xiàn)在python3提供了key-function,所以DSU方法已經(jīng)不常用了
python2.x版本中,是利用cmp參數(shù)自定義排序。
python3.x已經(jīng)將這個方法移除了,但是我們還是有必要了解一下cmp參數(shù)
cmp參數(shù)的使用方法就是指定一個函數(shù),自定義排序的規(guī)則,和java等其他語言很類似
也可以反序排列
python3.x中可以用如下方式:
當(dāng)前名稱:在python用函數(shù)排序 python編寫一個排序函數(shù)
轉(zhuǎn)載注明:http://jinyejixie.com/article22/dosdecc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃、外貿(mào)建站、企業(yè)建站、定制網(wǎng)站、自適應(yīng)網(wǎng)站、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)