python sorted排序

講一下python里的sorted排序

a = [
    {"time": "2012-12-12 00:00:00"},
    {"time": "2012-12-14 00:00:00"},
    {"time": "2012-12-16 00:00:00"},
    {"time": "2012-12-18 00:00:00"},
    {"time": "2012-12-16 00:00:00"},
    {"time": "2012-12-17 00:00:00"},
    {"time": "2012-12-10 00:00:00"},
    {"time": "2012-12-11 00:00:00"},
]

b = sorted(a, key=lambda d: d['time'])

b = [
    {'time': '2012-12-10 00:00:00'},
    {'time': '2012-12-11 00:00:00'},
    {'time': '2012-12-12 00:00:00'},
    {'time': '2012-12-14 00:00:00'},
    {'time': '2012-12-16 00:00:00'},
    {'time': '2012-12-16 00:00:00'},
    {'time': '2012-12-17 00:00:00'},
    {'time': '2012-12-18 00:00:00'}
]

sorted里key接受的是一個函數(shù),排序的時候柿菩,將key接收的函數(shù)分別作用于序列的子內(nèi)容戚嗅,然后通過key函數(shù)返回值排序。
如上所示碗旅,實際上sorted函數(shù)排序的是每個{"time":"xxxx"}time
亦可通過下面的快排實現(xiàn)

def QuickSort(L, low, high):
    """專用快排"""
    i = low
    j = high
    if i >= j:
        return L
    key = L[i]
    while i < j:
        while i < j and L[j]["time"] >= key["time"]:
            j = j - 1
        L[i] = L[j]
        while i < j and L[i]["time"] <= key["time"]:
            i = i + 1
        L[j] = L[i]
    L[i] = key
    QuickSort(L, low, i - 1)
    QuickSort(L, j + 1, high)
    return L[::-1]
def fun(a, b):
    if a["time"] > b["time"]:
        return -1
    else:
        return 1

c=sorted(a, cmp=fun)

c=[
    {'time': '2012-12-18 00:00:00'}, 
    {'time': '2012-12-17 00:00:00'}, 
    {'time': '2012-12-16 00:00:00'}, 
    {'time': '2012-12-16 00:00:00'},   
    {'time': '2012-12-14 00:00:00'}, 
    {'time': '2012-12-12 00:00:00'}, 
    {'time': '2012-12-11 00:00:00'}, 
    {'time': '2012-12-10 00:00:00'}
]

c=sorted(a, cmp=fun)意思是遍歷a列表的時候渡处,分別取相鄰的兩個數(shù)帶入fun函數(shù)中 如果fun函數(shù)返回的是正數(shù),則交換相鄰的兩個數(shù)據(jù)祟辟,反之医瘫,不交換


sorted還有個reverse參數(shù),表示是否逆序旧困,默認為reverse=False 升序排列醇份。


sort方法也一樣有這些功能

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市吼具,隨后出現(xiàn)的幾起案子僚纷,更是在濱河造成了極大的恐慌,老刑警劉巖拗盒,帶你破解...
    沈念sama閱讀 219,270評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怖竭,死亡現(xiàn)場離奇詭異,居然都是意外死亡陡蝇,警方通過查閱死者的電腦和手機痊臭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來登夫,“玉大人广匙,你說我怎么就攤上這事∧詹撸” “怎么了鸦致?”我有些...
    開封第一講書人閱讀 165,630評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長涣楷。 經(jīng)常有香客問我分唾,道長,這世上最難降的妖魔是什么狮斗? 我笑而不...
    開封第一講書人閱讀 58,906評論 1 295
  • 正文 為了忘掉前任鳍寂,我火速辦了婚禮,結(jié)果婚禮上情龄,老公的妹妹穿的比我還像新娘迄汛。我一直安慰自己捍壤,他們只是感情好,可當我...
    茶點故事閱讀 67,928評論 6 392
  • 文/花漫 我一把揭開白布鞍爱。 她就那樣靜靜地躺著,像睡著了一般睹逃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上沉填,一...
    開封第一講書人閱讀 51,718評論 1 305
  • 那天翼闹,我揣著相機與錄音,去河邊找鬼猎荠。 笑死,一個胖子當著我的面吹牛关摇,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播些楣,決...
    沈念sama閱讀 40,442評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼宪睹,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了横堡?” 一聲冷哼從身側(cè)響起命贴,我...
    開封第一講書人閱讀 39,345評論 0 276
  • 序言:老撾萬榮一對情侶失蹤胸蛛,失蹤者是張志新(化名)和其女友劉穎樱报,沒想到半個月后葬项,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體民珍,經(jīng)...
    沈念sama閱讀 45,802評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,984評論 3 337
  • 正文 我和宋清朗相戀三年陋桂,在試婚紗的時候發(fā)現(xiàn)自己被綠了蝶溶。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,117評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡梨州,死狀恐怖田轧,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情巷查,我是刑警寧澤抹腿,帶...
    沈念sama閱讀 35,810評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站警绩,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏后室。R本人自食惡果不足惜混狠,卻給世界環(huán)境...
    茶點故事閱讀 41,462評論 3 331
  • 文/蒙蒙 一贡避、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧杀捻,春花似錦仅仆、人聲如沸拄踪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽救恨。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間秸仙,已是汗流浹背寂纪。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留拟杉,地道東北人。 一個月前我還...
    沈念sama閱讀 48,377評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像卦洽,于是被迫代替她去往敵國和親阀蒂。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,060評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 文:鄭元春一個有著美好夢想的coder规肴! 人生苦短,我用Python拖刃。 P.S. 個人認為兑牡,查找和排序是算法的核心...
    北靜王閱讀 2,133評論 3 10
  • Python list內(nèi)置sort()方法用來排序,也可以用python內(nèi)置的全局sorted()方法來對可迭代的...
    Py_Explorer閱讀 435評論 1 2
  • 今天幫助三個新會員下訂單牛哺。 打調(diào)客服電話劳吠。 和婷婷玉芳商量幼兒園產(chǎn)品介紹會的事情痒玩。 建了一個新風系統(tǒng)團購群蠢古,增加了...
    季琳琳閱讀 500評論 0 0