1 回答

TA貢獻(xiàn)1784條經(jīng)驗(yàn) 獲得超8個(gè)贊
只要是可迭代對(duì)象都可以用sorted 。
sorted(itrearble, cmp=None, key=None, reverse=False)
=號(hào)后面是默認(rèn)值 默認(rèn)是升序排序的, 如果想讓結(jié)果降序排列,用reverse=True
最后會(huì)將排序的結(jié)果放到一個(gè)新的列表中, 而不是對(duì)iterable本身進(jìn)行修改。
eg:
1, 簡單排序
sorted('123456') 字符串
['1', '2', '3', '4', '5', '6']
sorted([1,4,5,2,3,6]) 列表
[1, 2, 3, 4, 5, 6]
sorted({1:'q',3:'c',2:'g'}) 字典, 默認(rèn)對(duì)字典的鍵進(jìn)行排序
[1, 2, 3]
sorted({1:'q',3:'c',2:'g'}.keys()) 對(duì)字典的鍵
[1, 2, 3]
sorted({1:'q',3:'c',2:'g'}.values()) 對(duì)字典的值
['c', 'g', 'q']
sorted({1:'q',3:'c',2:'g'}.items()) 對(duì)鍵值對(duì)組成的元組的列表
[(1, 'q'), (2, 'g'), (3, 'c')]
2, 對(duì)元素指定的某一部分進(jìn)行排序,關(guān)鍵字排序
s = ['Chr1-10.txt','Chr1-1.txt','Chr1-2.txt','Chr1-14.txt','Chr1-3.txt','Chr1-20.txt','Chr1-5.txt']
我想要按照-后的數(shù)字的大小升序排序。要用到key
sorted(s, key=lambda d : int(d.split('-')[-1].split('.')[0]))
['Chr1-1.txt', 'Chr1-2.txt', 'Chr1-3.txt', 'Chr1-5.txt', 'Chr1-10.txt', 'Chr1-14.txt', 'Chr1-20.txt']
這就是key的功能,制定排序的關(guān)鍵字,通常都是一個(gè)lambda函數(shù),當(dāng)然你也可以事先定義好這個(gè)函數(shù)。如果不講這個(gè)關(guān)鍵字轉(zhuǎn)化為整型,結(jié)果是這樣的:
sorted(s, key=lambda d : d.split('-')[-1].split('.')[0])
['Chr1-1.txt', 'Chr1-10.txt', 'Chr1-14.txt', 'Chr1-2.txt', 'Chr1-20.txt', 'Chr1-3.txt', 'Chr1-5.txt']
這相當(dāng)于把這個(gè)關(guān)鍵字當(dāng)做字符串了,很顯然,在python中,'2' > '10'
你可以定制你想要的key, 如 key = lambda x : len(x) 按照序列的長度去排序。key= lambda x : (x[1], x[0]) 按二個(gè)元素,再第一個(gè) 等等。。。
添加回答
舉報(bào)