閑來無事惹麻煩
閑的慌於是打算看下python基礎的一些函數,看到sorted的時候發現了比較怪異的排序需求,於是就有了這篇博文
1. 需求
大寫字母在前,小寫字母在后
所有的字母在數字前面
所有的奇數在偶數前面
2. 必須知道的sorted知識點
sorted函數如果返回的是一個元組, 那么排序規則是: 先對比所有元組的第一個元素, 再對比第二個...第n個
reverse參數為false, 為升序排列, 例如:
lst = [(0, 3), (0, 2), (1, 1)]
print(sorted(lst)) # reverse=Flase
第一次:[(0, 3),(0, 2),(1, 1)] # 和原來保持一致, 因為各個元組的第一個元素已經是升序了
第二次:[(0, 2),(0,3),(1,1)] # 原來列表的第一個元素和第二個元素位置互換, 因為(0,2)的第二個元素小於(0,3)的第二個元素,所以在前面
3. 被排序字符串str_sorted = 'H73Wo'
其實呢sorted(list1, key=lambda x: (x.isdigit(), x.isdigit() and int(x) % 2 == 0, x.islower(), x)) 和
sorted(lst, key=lambda x: (x.isdigit(), x.isdigit() and int(x) % 2 == 0, x.islower(), x.isupper(), x))過程效果是一毛一樣的
先說一下這個表達式是怎么得出的:
1. 首先我們被排序的字符串中的元素分為兩類: 1. 字母 2. 數字
2. 既然字母需要在前, 所以我們lambda函數結果中元組第一個元素一定要把字母和數字分開(# 這里直接用x.digist(), 如果為數字那么就一定在字母后面, 也就達到了我們的第二個目的)
3. 大寫字母要在小寫字母前, 那么就是大寫需要為False即x.lower()為假即可
4. 最后是奇數在偶數前: 即x.digist() and int(x) % 2 == 0 為真即可
5. 最最后如果還要求按照升序排列 則最后加一個x 即可
編號 | 元素 | 被sorted函數作用后的元素結果 |
---|---|---|
1 | Z | (False, False, False, Z) |
2 | 7 | (True, False, False, 7) |
3 | 2 | (True, True, False, 2) |
4 | W | (False, False, False, W) |
5 | o | (False, False, True, o) |
6 | 3 | (True, False, False, 3) |
第一次排序. 145 236 即 ZWo 723
第二次排序. 145 263 即 ZWo 732
第三次排序. 145 263 即 ZWo 732
第四次排序. 415 623 即 WZo 372
所以結果就出來啦['W', 'Z', 'o', '3', '7', '2']