作者:禪在心中
出處:http://www.cnblogs.com/pinking/
本文版權歸作者和博客園共有,歡迎批評指正及轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
有時候處理數據時,想要按照字符串中的數字的大小進行排序。
譬如,存在一組記錄文件,分別為‘1.dat’,'2.dat'...
當我把該文件夾中的所有記錄文件名讀到一個列表中,這些字符串的排列方式為:
如何讓這些字符串按照數字排列?
1、首先通過正則表達式,提取出字符串中的數字
2、排序,選擇built-in函數sorted進行排序
sorted(iterable, cmp=None, key=None, reverse=False)
iterable:是可迭代類型;
cmp:用於比較的函數,比較什么由key決定;
key:用列表元素的某個屬性或函數進行作為關鍵字,有默認值,迭代集合中的一項;
reverse:排序規則. reverse = True 降序 或者 reverse = False 升序,有默認值。
返回值:是一個經過排序的可迭代類型,與iterable一樣。
所以說排序方式按照數字拍的話,key就要對應里面的數字。
所以,這個問題只需一句話解決:
1
2
3
|
s
=
[
'1.dat'
,
'10.dat'
,
'5.dat'
]
new
=
sorted
(s,key
=
lambda
i:
int
(re.match(r
'(\d+)'
,i).group()))
print
new
|
得到的結果即為
對於該操作,同樣可以使用list.sort(),python2.4之后,list.sort和sorted都添加了一個key參數用來指定一個函數
不同的地方是:內置sorted返回一個新的列表,而list.sort是對列表進行操作
1
2
3
|
s
=
[
'1.dat'
,
'10.dat'
,
'5.dat'
]
s.sort(key
=
lambda
i:
int
(re.match(r
'(\d+)'
,i).group()))
print
s
|