Python中字符串List按照長度排序
下面看下字符串List按照長度排序(python)的實(shí)現(xiàn)方法
myList = ['青海省','內(nèi)蒙古自治區(qū)','西藏自治區(qū)','新疆維吾爾自治區(qū)','廣西壯族自治區(qū)']
1、首先得到每個(gè)字符串長度
2、排序,選擇sorted或者 list.sort()進(jìn)行排序
內(nèi)置sorted返回一個(gè)新的列表,而list.sort是對(duì)列表進(jìn)行操作
sorted(iterable, cmp=None, key=None, reverse=False)
iterable:是可迭代類型;
cmp:用于比較的函數(shù),比較什么由key決定;
key:用列表元素的某個(gè)屬性或函數(shù)進(jìn)行作為關(guān)鍵字,有默認(rèn)值,迭代集合中的一項(xiàng);
reverse:排序規(guī)則. reverse = True 降序 或者 reverse = False 升序,有默認(rèn)值。
返回值:是一個(gè)經(jīng)過排序的可迭代類型,與iterable一樣。
myList = ['青海省','內(nèi)蒙古自治區(qū)','西藏自治區(qū)','新疆維吾爾自治區(qū)','廣西壯族自治區(qū)'] myList1 = sorted(myList,key = lambda i:len(i),reverse=True) print(myList1) myList = ['青海省','內(nèi)蒙古自治區(qū)','西藏自治區(qū)','新疆維吾爾自治區(qū)','廣西壯族自治區(qū)'] myList.sort(key = lambda i:len(i),reverse=True) print(myList)
結(jié)果如下:
['新疆維吾爾自治區(qū)', '廣西壯族自治區(qū)', '內(nèi)蒙古自治區(qū)', '西藏自治區(qū)', '青海省']
PS:下面看下列表中字符串按照某種規(guī)則排序的方法(python)
有時(shí)候處理數(shù)據(jù)時(shí),想要按照字符串中的數(shù)字的大小進(jìn)行排序。
譬如,存在一組記錄文件,分別為‘1.dat','2.dat'...
當(dāng)我把該文件夾中的所有記錄文件名讀到一個(gè)列表中,這些字符串的排列方式為:
如何讓這些字符串按照數(shù)字排列?
1、首先通過正則表達(dá)式,提取出字符串中的數(shù)字
2、排序,選擇built-in函數(shù)sorted進(jìn)行排序
sorted(iterable, cmp=None, key=None, reverse=False)
iterable:是可迭代類型;
cmp:用于比較的函數(shù),比較什么由key決定;
key:用列表元素的某個(gè)屬性或函數(shù)進(jìn)行作為關(guān)鍵字,有默認(rèn)值,迭代集合中的一項(xiàng);
reverse:排序規(guī)則. reverse = True 降序 或者 reverse = False 升序,有默認(rèn)值。
返回值:是一個(gè)經(jīng)過排序的可迭代類型,與iterable一樣。
所以說排序方式按照數(shù)字拍的話,key就要對(duì)應(yīng)里面的數(shù)字。
所以,這個(gè)問題只需一句話解決:
s = ['1.dat','10.dat','5.dat'] new = sorted(s,key = lambda i:int(re.match(r'(\d+)',i).group())) print new
得到的結(jié)果即為
對(duì)于該操作,同樣可以使用list.sort(),python2.4之后,list.sort和sorted都添加了一個(gè)key參數(shù)用來指定一個(gè)函數(shù)
不同的地方是:內(nèi)置sorted返回一個(gè)新的列表,而list.sort是對(duì)列表進(jìn)行操作
s = ['1.dat','10.dat','5.dat'] s.sort(key = lambda i:int(re.match(r'(\d+)',i).group())) print s
總結(jié)
以上所述是小編給大家介紹的Python中字符串List按照長度排序,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
tensorflow中tf.reduce_mean函數(shù)的使用
這篇文章主要介紹了tensorflow中tf.reduce_mean函數(shù)的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04Django配置Bootstrap, js實(shí)現(xiàn)過程詳解
這篇文章主要介紹了Django配置Bootstrap, js實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10Python基于字典實(shí)現(xiàn)switch case函數(shù)調(diào)用
這篇文章主要介紹了Python基于字典實(shí)現(xiàn)switch case函數(shù)調(diào)用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07python通過pip更新所有已安裝的包實(shí)現(xiàn)方法
下面小編就為的帶來一篇python通過pip更新所有已安裝的包實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05Pycharm?debug程序,跳轉(zhuǎn)至指定循環(huán)條件/循環(huán)次數(shù)問題
這篇文章主要介紹了Pycharm?debug程序,跳轉(zhuǎn)至指定循環(huán)條件/循環(huán)次數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08簡單的Python動(dòng)態(tài)可視化神器,編程小白也能上手
這篇文章就來介紹簡單的Python動(dòng)態(tài)可視化神器,最近發(fā)現(xiàn)了一個(gè)寶藏動(dòng)態(tài)可視化庫,非常簡單,即使是小白也能輕松上手。這個(gè)庫就是motionchart,它能夠用 pandas 的 dataframe 數(shù)據(jù)直接創(chuàng)建交互式的動(dòng)態(tài)圖表,下面來簡單看一下如何使用。2021-10-10用python實(shí)現(xiàn)將數(shù)組元素按從小到大的順序排列方法
今天小編就為大家分享一篇用python實(shí)現(xiàn)將數(shù)組元素按從小到大的順序排列方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-07-07