這篇文章主要介紹了Python利用公共鍵對字典列表進(jìn)行排序的示例,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
成都創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比盂縣網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式盂縣網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋盂縣地區(qū)。費(fèi)用合理售后完善,十多年實(shí)體公司更值得信賴。問題描述
我們有一個字典列表,想根據(jù)一個或多個字典中的值來對列表排序。
例如,有如下字典列表,根據(jù)字典中的x,由大到小排序這個列表:
l = [{'x':1, 'y':2}, {'x':2, 'y':3}, {'x':3, 'y':4}]
解決方案
排序用sorted內(nèi)置函數(shù),關(guān)鍵字key參數(shù)用lambda表達(dá)式取出字典中x值作為排序依據(jù),關(guān)鍵字reverse參數(shù)設(shè)置為True用來由大到小降序排序。
>>> l = [{'x':1, 'y':2}, {'x':2, 'y':3}, {'x':3, 'y':4}] >>> l1 = sorted(l, key=lambda d:d['x'], reverse=True) >>> l1 [{'y': 4, 'x': 3}, {'y': 3, 'x': 2}, {'y': 2, 'x': 1}] >>>
也可以用operator模塊中的itemgetter函數(shù)取出字典中某個鍵的值,作為排序依據(jù)。
>>> from operator import itemgetter >>> l = [{'x':1, 'y':2}, {'x':2, 'y':3}, {'x':3, 'y':4}] >>> l2 = sorted(l, key=itemgetter('x'), reverse=True) >>> l2 [{'y': 4, 'x': 3}, {'y': 3, 'x': 2}, {'y': 2, 'x': 1}] >>>
討論
函數(shù)operator.itemgetter()
接受的參數(shù)可以作為查詢的標(biāo)記,它可以是字典的鍵名稱、用數(shù)字表示的列表元素或是任何可以傳給對象的__getitem__()
方法的值。如果傳多個標(biāo)記給itemgetter()
,那么它產(chǎn)生的可調(diào)用對象將返回一個包含所有元素在內(nèi)的元組,然后sorted()
將根據(jù)對元組的排序結(jié)果來排列輸出結(jié)果。如果想同時(shí)針對多個字段做排序(比如x和y),那么這是非常有用的。
有時(shí)候會用lambda表達(dá)式來取代itemgetter()
的功能。例如:
l_by_x = sorted(l, key=lambda d:d['x']) l_by_xy = sorted(l, key=lambda d:(d['x'], d['y']))
這種解決方案通常也能正常工作,但是用itemgetter()
通常會運(yùn)行得更快一些。因此如果要考慮性能問題的話,應(yīng)該使用itemgetter()
。
l_by_x = sorted(l, key=itemgetter('x')) l_by_xy = sorted(l, key=itemgetter('x', 'y'))
最后不要忘了本文中展示的技術(shù)同樣適用于min()
和max()
函數(shù)。例如:
>>> min(l, key=itemgetter('x')) {'y': 2, 'x': 1} >>> max(l, key=itemgetter('x', 'y')) {'y': 4, 'x': 3} >>> max(l, key=itemgetter('x')) {'y': 4, 'x': 3} >>>
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Python利用公共鍵對字典列表進(jìn)行排序的示例”這篇文章對大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!