python(46):对字典进行排序,多键值排序

字典,形如 dic = {'a':1 , 'b':2 , 'c': 3},字典中的元素没有顺序,所以dic[0]是有语法错误的。并且不可以有重复的键值,所以 dic.add['c'] = 4后,字典变成 {'a':1 , 'b':2 , 'c': 4}.

 

待解决问题

如何根据需要可以根据“键”或“键值”进行不同顺序的排序?

函数原型

sorted(dic,value,reverse)

  • dic为比较函数,value 为排序的对象(这里指键或键值),
  • reverse:注明升序还是降序,True--降序,False--升序(默认)

案例1:

单层字典排序

按照键排序:排序后要重新赋值

dic = {'a': 3, 'd': 1, 'b': 5, 'c': 7}

dicc = sorted(dic.items(),key = lambda asd:asd[0],reverse=True) #  按照键排序,从大到小 
>>> [('d', 1), ('c', 7), ('b', 5), ('a', 3)]

dicc = sorted(dic.items(),key = lambda asd:asd[0],reverse=False) #  按照键排序,从小到大
>>> [('a', 3), ('b', 5), ('c', 7), ('d', 1)]

dicc = sorted(dic.items(),key = lambda asd:asd[0]) #  默认从小到大
>>> [('a', 3), ('b', 5), ('c', 7), ('d', 1)]

dicc = sorted(dic.items(),key = lambda asd:asd[1],reverse=True)#  按照键值排序,从大到小
>>> [('c', 7), ('b', 5), ('a', 3), ('d', 1)]

dicc = sorted(dic.items(),key = lambda asd:asd[1],reverse=Flase)#  按照键值排序,从小到大
>>> [('d', 1), ('a', 3), ('b', 5), ('c', 7)]

注意:

排序之后原字典没有变,顺序依旧

     

案例2

多层排序

>>> a_dic = {'a':{'val':3}, 'b':{'val':4}, 'c':{'val':1}}
>>> dict= sorted(a_dic.items(), key=lambda d:d[1]['val'], reverse = True)
>>> dict
[('b', {'val': 4}), ('a', {'val': 3}), ('c', {'val': 1})]

 

例子中“键-值”对中的值是字典,例子对其进行排序。

那如果“键值”对中值字典的某一特定键不存在,咋处理呢,参考

>>> a = {'a':{'val':3}, 'b':{'val':4}, 'c':{'val':1}, 'd':{'val2':0}}
>>> a
{'a': {'val': 3}, 'c': {'val': 1}, 'b': {'val': 4}, 'd': {'val2': 0}}
>>> dict= sorted(a.items(), key=lambda d:d[1]['val'], reverse = True)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "<stdin>", line 1, in <lambda>
KeyError: 'val'
>>> dict= sorted(a.items(), key=lambda d:d[1].get('val',0), reverse = True)
>>> dict
[('b', {'val': 4}), ('a', {'val': 3}), ('c', {'val': 1}), ('d', {'val2': 0})]

 

案例3:

按照多个键值进行排序

先按照cpu,然后按照money

a = {'flavor15': {'cpu': '2', 'memory': 4}, 'flavor14': {'cpu': '2', 'memory': 2}, 'flavor8': {'cpu': '1', 'memory': 1}, 'flavor13': {'cpu': '1', 'memory': 4}, 'flavor12': {'cpu': 2, 'memory': 2}}
mm = sorted(a.items(),key=lambda item:(int(item[1]["cpu"]), int(item[1]["memory"])),reverse=True)
sorted:
[('flavor15', {'cpu': '2', 'memory': 4}), ('flavor14', {'cpu': '2', 'memory': 2}), ('flavor12', {'cpu': 2, 'memory': 2}), ('flavor13', {'cpu': '1', 'memory': 4}), ('flavor8', {'cpu': '1', 'memory': 1})]

两个函数

1.lambda

功能: 创建匿名函数

区别: 和def函数定义,以下两点区别

  • lambda会创建一个函数对象,但不会把这个函数对象赋给一个标识符;而def则会把函数对象赋值给一个变量
  • lambda它只是一个表达式,而def则是一个语句

案例:

    

2.iteritems()

功能: iteritems()以迭代器对象返回字典键值对

区别: 和item相比:items以列表形式返回字典键值对

案例:

    

注释: 在函数sorted(dic.iteritems(), key = lambda asd:asd[1])中,第一个参数传给第二个参数“键-键值”,第二个参数取出其中的键([0])或键值(1])

 

 
posted on 2017-08-24 17:03  细雨微光  阅读(9000)  评论(0编辑  收藏  举报