標籤:tail compile false 常用 net 列表 style pre [1]
當我們從資料庫中擷取一寫資料後,一般對於列表的排序是經常會遇到的問題,今天總結一下python對於列表list排序的常用方法:
第一種:內建函數sort()
這個應該是我們使用最多的也是最簡單的排序函數了,可以直接對列表進行排序
用法:
list.sort(func=None, key=None, reverse=False(or True))
對於reverse這個bool型別參數,當reverse=False時:為正向排序;當reverse=True時:為方向排序。當然預設為False。
執行完後會改變原來的list
例如:
>>> list = [2,8,4,6,9,1,3]>>> list.sort()>>> list[1, 2, 3, 4, 6, 8, 9]
第二種:序列類型函數sorted()
這個和第一種的差別之處在於,其不會改變原來的list,而是會返回一個對象
用法:
sorted(list)
同樣跟第一種方法一樣,該函數也含有reverse這個bool類型的參數,當reverse=False時:為正向排序(從小到大);當reverse=True時:為反向排序(從大到小)。當然預設為False。
執行完後會有返回一個新的排序好的list對象
例如:
>>> list = [2,8,4,1,5,7,3]>>> other = sorted(list)>>> other[1, 2, 3, 4, 5, 7, 8]
當然,有時候我們會遇到這種情況,那就是列表裡面每一個元素不止一個元素(比如:列表裡面,元素為元祖類型),我們除了想對第一個關鍵字排序之外,還想在第一次的基礎上面根據第二個關鍵字進行排序,那麼我們可以使用第三種方法。
第三種:
這種方法其實就是基於第二種sorted()函數排序的擴充。這裡需要用到 lambda 運算式。
先看一個例子:
我們想先排序列表list中元素的第一個關鍵字,然後在第一個元素的基礎上排序按第二個關鍵字進行排序,看結果:
>>> list = [(‘d‘,3),(‘a‘,5),(‘d‘,1),(‘c‘,2),(‘d‘,2)]>>> print sorted(list, key = lambda x:(x[0],x[1]))[(‘a‘, 5), (‘c‘, 2), (‘d‘, 1), (‘d‘, 2), (‘d‘, 3)]
還有一種:
今天遇到了這麼一個問題,就是遇到一個字串的處理問題,比如說 f10 得排在 f2 的後面。找到了這麼一種方法,供參考:
參考地址:http://blog.csdn.net/houyj1986/article/details/22966799
#encoding=utf-8 print ‘中國‘ #根據字串中的數字排序,如f10應該在f2後面 import re re_digits = re.compile(r‘(\d+)‘) def emb_numbers(s): pieces=re_digits.split(s) pieces[1::2]=map(int,pieces[1::2]) return pieces def sort_strings_with_emb_numbers(alist): aux = [(emb_numbers(s),s) for s in alist] aux.sort() return [s for __,s in aux] def sort_strings_with_emb_numbers2(alist): return sorted(alist, key=emb_numbers) filelist=‘file10.txt file2.txt file1.txt‘.split() print filelist print ‘--DSU排序‘ print sort_strings_with_emb_numbers(filelist) print ‘--內建DSU排序‘ print sort_strings_with_emb_numbers2(filelist)
列印結果如下:
中國[‘file10.txt‘, ‘file2.txt‘, ‘file1.txt‘]--DSU排序[‘file1.txt‘, ‘file2.txt‘, ‘file10.txt‘]--內建DSU排序[‘file1.txt‘, ‘file2.txt‘, ‘file10.txt‘]
Python list列表的排序