1. 程式人生 > >Python3 對列表按元組指定列進行排序

Python3 對列表按元組指定列進行排序

Python版本: python3.+
執行環境: Mac OS
IDE: pycharm

Python內建的排序方法

1 排序方法介紹

Python中有2個排序函式,一個是list內建的sort()方法,另一個是全域性的sorted()方法

sorted(iterable,key=None,reverse
=False) #返回排好序的新列表,不改變物件本身,預設升序;reverse:-True降序 -False 正序對所有可迭代的物件均有效 list.sort(key=None,reverse=False) #將list自身進行排序,不返回新的list物件,預設升序;reverse:-True降序 -False 正序

2 基本的列表排序

1)list.sort()排序

data = [5, 7, 9, 3, -6, -7, -8, -9, 3, -8]
result = data.sort()
print(data) #結果為 [-9, -8, -8, -7, -6, 3, 3, 5, 7, 9]
print(result) #結果為None

2)sorted()排序

    data = [5, 7, 9, 3, -6, -7, -8, -9, 3, -8]
    result = sorted(data)
    print(data) #結果為 [5, 7, 9, 3, -6, -7, -8, -9, 3, -8]
    print(result) #結果為 [-9, -8, -8, -7, -6, 3, 3, 5, 7, 9]

3 以tuple作為list的元素

在預設情況下sort和sorted函式接收的引數是元組時,它將會先按元組的第一個元素進行排序再按第二個元素進行排序,再按第三個、第四個…依次排序。
我們通過一個簡單的例子來了解它,以下面這個list為例:

data = [(1, 'B'), (1, 'A'), (2, 'A'), (0, 'B'), (0, 'a')]

我們通過sorted()對它進行排序

data = [(1, 'B'), (1, 'A'), (2, 'A'), (0, 'B'), (0, 'a')]
result = sorted(data)
print(data) #結果為 [(1, 'B'), (1, 'A'), (2, 'A'), (0, 'B'), (0, 'a')]
print(result) #結果為 [(0, 'B'), (0, 'a'), (1, 'A'), (1, 'B'), (2, 'A')]

會發現排序後的結果中(0, ‘B’)在(0, ‘a’)的前面。這是因為在按元組第一個元素排好之後,將(0, ‘B’), (0, ‘a’)再按第二個元素進行排序了,而’B’的ASCII編碼比’a’小,所以(0, ‘B’)就排在(0, ‘a’)的前面了。

那如何想要讓它排序時不分大小寫呢?

這就要用到sort方法和sorted方法裡的key引數了。
我們來看一下具體的實現:

data = [(1, 'B'), (1, 'A'), (2, 'A'), (0, 'B'), (0, 'a')]
#利用引數key來規定排序的規則
result = sorted(data,key=lambda x:(x[0],x[1].lower()))

print(data) #結果為 [(1, 'B'), (1, 'A'), (2, 'A'), (0, 'B'), (0, 'a')]
print(result) #結果為 [(0, 'a'), (0, 'B'), (1, 'A'), (1, 'B'), (2, 'A')]

其中的lambda x:(x[0],x[1].lower()可以理解為一個匿名函式;
其功能類似於:

def fun(x)
    return(x[0],x[1].lower())

如果想要以字母作為第一排序規則,並且字母大小寫不敏感,該怎麼實現?
這就能要運用到之前所講到的

在預設情況下sort和sorted函式接收的引數是元組時,它將會先按元組的第一個元素進行排序再按第二個元素進行排序,再按第三個、第四個…依次排序。

再配合lambda返回一個自定義tuple;程式碼如下:

data = [(1, 'B'), (1, 'A'), (2, 'A'), (0, 'B'), (0, 'a')]
#將x[1].lower()作為返回元組裡的第一個元素,按照sorted的排序規律,就會先按字母排序,再按數字排序了
result = sorted(data,key=lambda x:(x[1].lower(),x[0]))

print(data) #結果為 [(1, 'B'), (1, 'A'), (2, 'A'), (0, 'B'), (0, 'a')] 
print(result) #結果為 [(0, 'a'), (1, 'A'), (2, 'A'), (0, 'B'), (1, 'B')]

4 [擴充套件] 以dict作為list的元素

這個list裡的元素是dict形式,每個dict都存有姓名升高現在想要以升高進行升序排列:

data = [{'name': '張三', 'height': 175}, {'name': '李四', 'height': 165}, {'name': '王五', 'height': 185}]
#將x['height']最為返回tuple的第個一元素
result = sorted(data,key=lambda x:(x['height'],x['name']))
print(data) #結果為 
print(result)
#data   結果:[{'name': '張三', 'height': 175}, {'name': '李四', 'height': 165}, {'name': '王五', 'height': 185}]
#result 結果:[{'name': '李四', 'height': 165}, {'name': '張三', 'height': 175}, {'name': '王五', 'height': 185}]