Ответ 1
Вы можете сделать это следующим образом:
list.sort(key=lambda item:item['date'], reverse=True)
У меня есть список, и я добавляю словарь к нему, когда я просматриваю свои данные... и я хотел бы сортировать по одному из ключей словаря.
ex:
data = "data from database"
list = []
for x in data:
dict = {'title':title, 'date': x.created_on}
list.append(dict)
Я хочу сортировать список в обратном порядке по значению 'date'
Вы можете сделать это следующим образом:
list.sort(key=lambda item:item['date'], reverse=True)
from operator import itemgetter
your_list.sort(key=itemgetter('date'), reverse=True)
не использовать list
, dict
как имена переменных, они являются встроенными именами в Python. Это делает ваш код трудным для чтения.
вам может потребоваться заменить словарь tuple
или collections.namedtuple
или настраиваемый структуроподобный класс в зависимости от контекста
from collections import namedtuple
from operator import itemgetter
Row = namedtuple('Row', 'title date')
rows = [Row(row.title, row.created_on) for row in data]
rows.sort(key=itemgetter(1), reverse=True)
Пример:
>>> lst = [Row('a', 1), Row('b', 2)]
>>> lst.sort(key=itemgetter(1), reverse=True)
>>> lst
[Row(title='b', date=2), Row(title='a', date=1)]
Или
>>> from operator import attrgetter
>>> lst = [Row('a', 1), Row('b', 2)]
>>> lst.sort(key=attrgetter('date'), reverse=True)
>>> lst
[Row(title='b', date=2), Row(title='a', date=1)]
Здесь namedtuple
выглядит внутри:
>>> Row = namedtuple('Row', 'title date', verbose=True)
class Row(tuple):
'Row(title, date)'
__slots__ = ()
_fields = ('title', 'date')
def __new__(cls, title, date):
return tuple.__new__(cls, (title, date))
@classmethod
def _make(cls, iterable, new=tuple.__new__, len=len):
'Make a new Row object from a sequence or iterable'
result = new(cls, iterable)
if len(result) != 2:
raise TypeError('Expected 2 arguments, got %d' % len(result))
return result
def __repr__(self):
return 'Row(title=%r, date=%r)' % self
def _asdict(t):
'Return a new dict which maps field names to their values'
return {'title': t[0], 'date': t[1]}
def _replace(self, **kwds):
'Return a new Row object replacing specified fields with new values'
result = self._make(map(kwds.pop, ('title', 'date'), self))
if kwds:
raise ValueError('Got unexpected field names: %r' % kwds.keys())
return result
def __getnewargs__(self):
return tuple(self)
title = property(itemgetter(0))
date = property(itemgetter(1))
Отсортируйте данные (или копию данных) напрямую и впоследствии создайте список dicts. Сортировка с использованием функции, отсортированной с подходящей ключевой функцией (возможно, operator.attrgetter)
У меня на самом деле был этот почти точный вопрос вчера, и решил его с помощью поиска. Лучший ответ на ваш вопрос:
from operator import itemgetter
list.sort(key=itemgetter('date'), reverse=True)
Если вы входите во всю краткость:
data = "data from database"
sorted_data = sorted(
[{'title': x.title, 'date': x.created_on} for x in data],
key=operator.itemgetter('date'),
reverse=True)