OrderedDict 排序不正确
OrderedDict sorting incorrectly
据我了解,以下内容应生成一个 OrderedDict
对象,其中的项目按键排序,这是一个日期时间对象。
ledger = OrderedDict(
sorted(ledger.items(), key=lambda x: datetime.strftime(x[0], '%d-%m-%Y'))
)
但是,在我的例子中,对象的排序是乱序的:
OrderedDict([
(datetime.date(2021, 10, 1), {'net': -33924, 'entries': [{'text': 'Applied to 102101', 'amount': -16962, 'mode': 'debit'}, {'text': 'Applied to 102104', 'amount': -16962, 'mode': 'debit'}]}),
(datetime.date(2021, 11, 3), {'net': -96118, 'entries': [{'text': 'Applied to 102104', 'amount': -96118, 'mode': 'debit'}]}),
(datetime.date(2021, 9, 24), {'net': 18000.0, 'entries': [{'text': 'Payment Received', 'amount': 18000.0, 'mode': 'credit'}]})
])
我在这里遗漏了哪些注意事项?
如果您想以某种不是时间顺序的方式排序,您可以访问您想要排序的属性并使用元组排序:
sorted(datetimes, key=lambda d: (d.month, d.seconds)) # or some other weird sorting
但是,如果它只是按时间顺序排序,那么您无需为这些烦恼:
In [3]: OrderedDict(sorted(ledger.items()))
Out[3]:
OrderedDict([(datetime.date(2021, 9, 24),
{'net': 18000.0,
'entries': [{'text': 'Payment Received',
'amount': 18000.0,
'mode': 'credit'}]}),
(datetime.date(2021, 10, 1),
{'net': -33924,
'entries': [{'text': 'Applied to 102101',
'amount': -16962,
'mode': 'debit'},
{'text': 'Applied to 102104',
'amount': -16962,
'mode': 'debit'}]}),
(datetime.date(2021, 11, 3),
{'net': -96118,
'entries': [{'text': 'Applied to 102104',
'amount': -96118,
'mode': 'debit'}]})])
据我了解,以下内容应生成一个 OrderedDict
对象,其中的项目按键排序,这是一个日期时间对象。
ledger = OrderedDict(
sorted(ledger.items(), key=lambda x: datetime.strftime(x[0], '%d-%m-%Y'))
)
但是,在我的例子中,对象的排序是乱序的:
OrderedDict([
(datetime.date(2021, 10, 1), {'net': -33924, 'entries': [{'text': 'Applied to 102101', 'amount': -16962, 'mode': 'debit'}, {'text': 'Applied to 102104', 'amount': -16962, 'mode': 'debit'}]}),
(datetime.date(2021, 11, 3), {'net': -96118, 'entries': [{'text': 'Applied to 102104', 'amount': -96118, 'mode': 'debit'}]}),
(datetime.date(2021, 9, 24), {'net': 18000.0, 'entries': [{'text': 'Payment Received', 'amount': 18000.0, 'mode': 'credit'}]})
])
我在这里遗漏了哪些注意事项?
如果您想以某种不是时间顺序的方式排序,您可以访问您想要排序的属性并使用元组排序:
sorted(datetimes, key=lambda d: (d.month, d.seconds)) # or some other weird sorting
但是,如果它只是按时间顺序排序,那么您无需为这些烦恼:
In [3]: OrderedDict(sorted(ledger.items()))
Out[3]:
OrderedDict([(datetime.date(2021, 9, 24),
{'net': 18000.0,
'entries': [{'text': 'Payment Received',
'amount': 18000.0,
'mode': 'credit'}]}),
(datetime.date(2021, 10, 1),
{'net': -33924,
'entries': [{'text': 'Applied to 102101',
'amount': -16962,
'mode': 'debit'},
{'text': 'Applied to 102104',
'amount': -16962,
'mode': 'debit'}]}),
(datetime.date(2021, 11, 3),
{'net': -96118,
'entries': [{'text': 'Applied to 102104',
'amount': -96118,
'mode': 'debit'}]})])