python多列排序函數(shù) python多個列表排序

sorted函數(shù)python

sorted函數(shù)python介紹如下

成都創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站建設(shè)、成都網(wǎng)站制作、常山網(wǎng)絡(luò)推廣、重慶小程序開發(fā)、常山網(wǎng)絡(luò)營銷、常山企業(yè)策劃、常山品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供常山建站搭建服務(wù),24小時服務(wù)熱線:13518219792,官方網(wǎng)址:www.muchs.cn

sorted() 作為?Python?內(nèi)置函數(shù)之一,其功能是對序列(列表、元組、字典、集合、還包括字符串)進行排序。

sorted() 函數(shù)的基本語法格式如下

list = sorted(iterable, key=None, reverse=False)

其中,iterable 表示指定的序列,key 參數(shù)可以自定義排序規(guī)則;reverse 參數(shù)指定以升序(False,默認(rèn))還是降序(True)進行排序。sorted() 函數(shù)會返回一個排好序的列表。

注意,key 參數(shù)和 reverse 參數(shù)是可選參數(shù),即可以使用,也可以忽略。

演示sorted()函數(shù)的基本代碼用法:

#對列表進行排序

a = [5,3,4,2,1]

print(sorted(a))

#對元組進行排序

a = (5,4,3,1,2)

print(sorted(a))

#字典默認(rèn)按照key進行排序

a = {4:1,\

5:2,\

3:3,\

2:6,\

1:8}

print(sorted(a.items()))

#對集合進行排序

a = {1,5,3,2,4}

print(sorted(a))

#對字符串進行排序

a = "51423"

print(sorted(a))

python 內(nèi)置排序函數(shù)使用

python內(nèi)置關(guān)于排序的工具主要有兩個一個是列表自帶的 sort() 方法,另外一個是 sorted() 函數(shù)。Python 列表內(nèi)置方法可以直接修改列表。而 sorted() 內(nèi)置函數(shù)從一個可迭代對象(列表,元組等都可以)構(gòu)建一個新的排序列表。其函數(shù)原型分別如下:

對列表進行默認(rèn)排序

從函數(shù)原型來看,可以看到兩者都具有兩個可選參數(shù),它們都必須指定為關(guān)鍵字參數(shù)。

key 指定帶有單個參數(shù)的函數(shù),用于從 iterable 的每個元素中提取用于比較的鍵 (例如 key=str.lower)。默認(rèn)值為 None (直接比較元素)。 key 形參的值應(yīng)該是個函數(shù)(或其他可調(diào)用對象),它接受一個參數(shù)并返回一個用于排序的鍵。

假設(shè)有其他類型的變量,比如一個自定義的類或者列表中又是一個列表。以官網(wǎng)例子為例有這樣一個列表,其元素為元組,

可以用以下方式按照年齡排序

類似的有自定義類

可以用如下方式進行排序

也可以顯示定義一個函數(shù),且只有一個參數(shù),返回用于排序的鍵,比如

總之就是定義一個函數(shù)返回一個用于排序的鍵,可以用lambda函數(shù)或者 def 定義都可以。

上面實現(xiàn)的簡單函數(shù)實際就是實現(xiàn)了返回一個有序結(jié)構(gòu)的第 n 的元素,或者某個類中的某個屬性,因此 Python 提供了便利功能,使訪問器功能更容易,更快捷。operator 模塊有 itemgetter() 、 attrgetter() 函數(shù)。分別完成返回第 n 個元素,某個屬性功能。上面的排序可以用如下方式進行實現(xiàn)

在python2中,sort有一個 cmp 參數(shù),即用一個函數(shù)來自定義比較,在python3中這種方式被取消。為了繼承類似的用法,在 Python 3.2 中, functools.cmp_to_key() 函數(shù)被添加到標(biāo)準(zhǔn)庫中的 functools 模塊中。

這種作用先定義如何比較兩個變量,以上面的學(xué)生列表按照年齡排序為例

這種做法自定義比較函數(shù)接收兩個形參,返回比較結(jié)果(bool),而新式方法接受一個參數(shù),返回的是比較的鍵。

假設(shè)有字典 d = {'b':2, 'a':1,'c':8,'d':4} ,則可以通過以下方式對字典按照鍵和值進行排序

如何對列表進行排序?python

很多時候,我們需要對List進行排序,Python提供了兩個方法,對給定的List

L進行排序:

方法1.用List的成員函數(shù)sort進行排序

方法2.用built-in函數(shù)sorted進行排序(從2.4開始)

這兩種方法使用起來差不多,以第一種為例進行講解:

從Python2.4開始,sort方法有了三個可選的參數(shù),Python

Library

Reference里是這樣描述的

復(fù)制代碼代碼如下:

cmp:cmp

specifies

a

custom

comparison

function

of

two

arguments

(iterable

elements)

which

should

return

a

negative,

zero

or

positive

number

depending

on

whether

the

first

argument

is

considered

smaller

than,

equal

to,

or

larger

than

the

second

argument:

"cmp=lambda

x,y:

cmp(x.lower(),

y.lower())"

key:key

specifies

a

function

of

one

argument

that

is

used

to

extract

a

comparison

key

from

each

list

element:

"key=str.lower"

reverse:reverse

is

a

boolean

value.

If

set

to

True,

then

the

list

elements

are

sorted

as

if

each

comparison

were

reversed.In

general,

the

key

and

reverse

conversion

processes

are

much

faster

than

specifying

an

equivalent

cmp

function.

This

is

because

cmp

is

called

multiple

times

for

each

list

element

while

key

and

reverse

touch

each

element

only

once.

以下是sort的具體實例。

實例1:

復(fù)制代碼代碼如下:

L

=

[2,3,1,4]

L.sort()

L

[1,2,3,4]

實例2:

復(fù)制代碼代碼如下:

L

=

[2,3,1,4]

L.sort(reverse=True)

L

[4,3,2,1]

實例3:

復(fù)制代碼代碼如下:

L

=

[('b',2),('a',1),('c',3),('d',4)]

L.sort(cmp=lambda

x,y:cmp(x[1],y[1]))

L

[('a',

1),

('b',

2),

('c',

3),

('d',

4)]

實例4:

復(fù)制代碼代碼如下:

L

=

[('b',2),('a',1),('c',3),('d',4)]

L.sort(key=lambda

x:x[1])

L

[('a',

1),

('b',

2),

('c',

3),

('d',

4)]

實例5:

復(fù)制代碼代碼如下:

L

=

[('b',2),('a',1),('c',3),('d',4)]

import

operator

L.sort(key=operator.itemgetter(1))

L

[('a',

1),

('b',

2),

('c',

3),

('d',

4)]

實例6:(DSU方法:Decorate-Sort-Undercorate)

復(fù)制代碼代碼如下:

L

=

[('b',2),('a',1),('c',3),('d',4)]

A

=

[(x[1],i,x)

for

i,x

in

enumerate(L)]

#i

can

confirm

the

stable

sort

A.sort()

L

=

[s[2]

for

s

in

A]

L

[('a',

1),

('b',

2),

('c',

3),

('d',

4)]

以上給出了6中對List排序的方法,其中實例3.4.5.6能起到對以List

item中的某一項

為比較關(guān)鍵字進行排序.

效率比較:

復(fù)制代碼代碼如下:

cmp

DSU

key

通過實驗比較,方法3比方法6要慢,方法6比方法4要慢,方法4和方法5基本相當(dāng)

多關(guān)鍵字比較排序:

實例7:

復(fù)制代碼代碼如下:

L

=

[('d',2),('a',4),('b',3),('c',2)]

L.sort(key=lambda

x:x[1])

L

[('d',

2),

('c',

2),

('b',

3),

('a',

4)]

我們看到,此時排序過的L是僅僅按照第二個關(guān)鍵字來排的,如果我們想用第二個關(guān)鍵字

排過序后再用第一個關(guān)鍵字進行排序呢?有兩種方法

實例8:

復(fù)制代碼代碼如下:

L

=

[('d',2),('a',4),('b',3),('c',2)]

L.sort(key=lambda

x:(x[1],x[0]))

L

[('c',

2),

('d',

2),

('b',

3),

('a',

4)]

實例9:

復(fù)制代碼代碼如下:

L

=

[('d',2),('a',4),('b',3),('c',2)]

L.sort(key=operator.itemgetter(1,0))

L

[('c',

2),

('d',

2),

('b',

3),

('a',

4)]

為什么實例8能夠工作呢?原因在于tuple是的比較從左到右之一比較的,比較完第一個,如果

相等,比較第二個

python列表排序方法

列表的sort方法就是用來進行排序的。

主要就是兩個參數(shù),key,reverse

先說reverse,這個很簡單,就是指出是否進行倒序排序:一般情況下,1排在2的前面,而倒序則相反。

key參數(shù):一般它是一個函數(shù),它接受列表中每一個元素,返回一個可用用于比較的值。

s=[1,2,3,4,5]

s.sort(key=lambda _: _**2%7)

print(s)

輸出的是:[1, 3, 4, 2, 5]

如果看不懂lambda表達(dá)式,可以看這一段等價的寫法:

def myfn(x):

....return (x * x) % 7

s=[1,2,3,4,5]

s.sort(key=myfn)

print(s)

輸出的結(jié)果是一樣的。

key使用的函數(shù)可以是自定義函數(shù)也可以pytho內(nèi)置的函數(shù),或者是某個類或者實例的方法,只要它能接受一個參數(shù),返回一個可比較的值即可。比如這樣:

s=[[1,2,4],[3,3,5],[1,1,1],[5,7,9]]

s.sort(key=max)? # 直接使用max函數(shù)作為排序依據(jù)

print(s)

[[1, 1, 1], [1, 2, 4], [3, 3, 5], [5, 7, 9]]

名稱欄目:python多列排序函數(shù) python多個列表排序
標(biāo)題URL:http://www.muchs.cn/article0/hhehoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、ChatGPT、網(wǎng)站收錄、網(wǎng)站內(nèi)鏈網(wǎng)站建設(shè)、商城網(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)

綿陽服務(wù)器托管