⑴ python 二維列表,用sorted函數怎麼多重排序
在歷返歷Python中,使用sorted函數對二維列表進行多重排序可以使用key參數。key參數接收一個函數,該函數接收一個列表元素作為參數世皮,返回一個用肢搜於排序的值。可以使用lambda函數來實現多重排序,例如:
sorted_list = sorted(my_list, key=lambda x:(x[1],x[2],x[0]))
這將按第1個元素,第2個元素,第3個元素的順序對二維列表進行排序。
⑵ 在python中以某列為分組對象還能對某列進行依次排序嗎
親你好,Python教程:在python中對列表進行排序詳解 Python知識,本文學習的是《在Python中對列表進行排序詳解》。本知識點主要內容有:使用列表對象的sort()方法進行排序、使用內置的sorted()函數進行排序、使用reverse()方法進行反向排序。
在Python實際開發中,會經常需要用到對列表進行排序。下面站長在線對列表的排序講解幾種常用的方法:
1、使用列表對象的sort()方法進行排序。
列表對象提供了sort()方法用於對原列表中的元素進行排序。排序以後,原列表中的元素順序將發生改變。列表對象的sort()方法的語法格式如下:
listname.sort(key=None,reverse=False)
相關的參數說明如下:
listname:表示要進行排序的列表。
key:表示指定一個從每個列表元素中提取一個比較鍵。(列如,設置「key=str.lower」表示在排序時不區分字母的大小寫)。
reverse:可選參數,如果將其值指定為True,則表示降序排序;如果將其指定為False,則表示升序排列。默認為升序排列。
列如,某中學初三1班的10名男學生的數學成績,然後應用sort()方法對其進行排序,代碼如下:
s = [93,95,86,98,99,99,89,100,100,97]
print("原列表:",s)
s.sort()
print("升序:",s)
s.sort(reverse=True)
print("降序:",s)
執行結果如下:
原列表: [93, 95, 86, 98, 99, 99, 89, 100, 100, 97]
升序: [86, 89, 93, 95, 97, 98, 99, 99, 100, 100]
降序: [100, 100, 99, 99, 98, 97, 95, 93, 89, 86]
>>>
使用sort()方法除了可以對數值進行排序,還可以多字元串進行排序。對字元串進行排序默認區分大小寫,如果想不區分大小寫,則需要指定其key參數。
列如,定義保存一個大小寫不同的英文字元串列表,然後應用sort()方法對其進行排序,代碼如下:
s = ['hello','polly','Lucy','Lily','Han Meimei']
s.sort()
print("區分字母大小寫:",s)
s.sort(key=str.lower)
print("不區分字母大小寫:",s)
運行結果如下:
區分字母大小寫: ['Han Meimei', 'Lily', 'Lucy', 'hello', 'polly']
不區分字母大小寫: ['Han Meimei', 'hello', 'Lily', 'Lucy', 'polly']
>>>
說明:sort()方法對列表排序時,最中文的支持不好,排序的結果與我們常用的按拼音排序或者筆畫排序都不一致。要想實現對中文內容的排序,需要重新編寫相應的方法,不能直接使用sort()方法
⑶ python常見的三種列表排序演算法分別是什麼
排序是計算機程序設計中的一種重要操作,它的功能是將一個數據元素的任意序列,重新排列成一個關鍵字有序的序列。那麼python列表排序演算法有哪些?本文主要為大家講述python中經常用的三種排序演算法:冒泡排序、插入排序和選擇排序。
1、冒泡排序
冒泡排序,Bubble
Sort,是一種簡單的排序演算法。它重復地遍歷要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。遍歷數列的工作是重復地進行直到沒有再需要交換,也就是說該數列已經排序完成。這個演算法的名字由來是因為越小的元素會經由交換慢慢浮到數列的頂端。
2、插入排序
插入排序,Insertion
Sort,是一種簡單直觀的排序演算法。它的工作原理是通過構建有序序列,對於未排序數據,在已排序序列中從後向前掃描,找到相應位置並插入。插入排序在實現上,在從後向前的掃描過程中,需要把已排序元素逐步向後挪位,為最新元素提供插入空間。
3、選擇排序
選擇排序,Selection
Sort,是一種簡單直觀的排序演算法。它的工作原理如下:首先在未排序序列中找到最小、最大元素,存放到排序序列的起始位置,然後再從剩餘未排序元素中繼續尋找最小、最大元素。放到已排序序列的末尾。以此類推,直到所有元素均排序完畢。