Как отсортировать OrderedDict из OrderedDict - Python - PullRequest
45 голосов
/ 07 ноября 2011

Я пытаюсь отсортировать OrderedDict в OrderedDict по ключу 'глубина' . Есть ли решение для сортировки этого словаря?

OrderedDict([
  (2, OrderedDict([
    ('depth', 0),  
    ('height', 51), 
    ('width', 51),   
    ('id', 100)
  ])), 
  (1, OrderedDict([
    ('depth', 2),  
    ('height', 51), 
    ('width', 51),  
    ('id', 55)
  ])), 
  (0, OrderedDict([
    ('depth', 1),  
    ('height', 51), 
    ('width', 51),  
    ('id', 48)
  ])),
]) 

Сортировка должна выглядеть так:

OrderedDict([
  (2, OrderedDict([
    ('depth', 0),  
    ('height', 51), 
    ('width', 51),   
    ('id', 100)
  ])), 
  (0, OrderedDict([
    ('depth', 1),  
    ('height', 51), 
    ('width', 51),  
    ('id', 48)
  ])),
  (1, OrderedDict([
    ('depth', 2),  
    ('height', 51), 
    ('width', 51),  
    ('id', 55)
  ])), 
]) 

есть идеи как это получить?

Ответы [ 3 ]

89 голосов
/ 07 ноября 2011

Вам придется создать новый, поскольку OrderedDict отсортировано по порядку вставки.

В вашем случае код будет выглядеть следующим образом:

foo = OrderedDict(sorted(foo.iteritems(), key=lambda x: x[1]['depth']))

См. http://docs.python.org/dev/library/collections.html#ordereddict-examples-and-recipes для дополнительных примеров.

Примечание для Python 3 вам нужно будет использовать .items() вместо .iteritems().

15 голосов
/ 07 ноября 2011
>>> OrderedDict(sorted(od.items(), key=lambda item: item[1]['depth']))
3 голосов
/ 05 апреля 2018

Иногда вам может потребоваться сохранить исходный словарь, а не создавать новый.

В этом случае вы можете сделать следующее:

temp = sorted(list(foo.items()), key=lambda x: x[1]['depth'])
foo.clear()
foo.update(temp)
...