Python--列表中字符串按照某種規則排序的方法



作者:禪在心中 

出處: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
=  [ '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
=  [ '1.dat' , '10.dat' , '5.dat' ]
s.sort(key  =  lambda  i: int (re.match(r '(\d+)' ,i).group()))
print  s

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM