复杂的dict,按照dict对象中某一个属性进行排序
lst = [{'level': 30, 'star': 80, 'time': 1},
{'level': 40, 'star': 90, 'time': 2},
{'level': 60, 'star': 60, 'time': 3},
{'level': 10, 'star': 10, 'time': 4},
{'level': 10, 'star': 50, 'time': 5},
{'level': 50, 'star': 40, 'time': 1}]
需求:
level越大越靠前;
level相同, star越大越靠前;
level和star相同, time越小越靠前;
# 先按time排序
lst.sort(key=lambda k: (k.get('time', 0)))
# 再按照level和star顺序
# reverse=True表示反序排列,默认正序排列
lst.sort(key=lambda k: (k.get('level', 0), k.get('star', 0)), reverse=True)