【问题标题】:Python sort a list of objects/dictionaries with a given sortKey functionPython 使用给定的 sortKey 函数对对象/字典列表进行排序
【发布时间】:2016-08-05 16:15:01
【问题描述】:

(我在这里使用 Python 2)

我有一个字典列表,比如说

dei = [{'name': u'Thor'}, {'name': u'Œdipus'}, {'name': u'Creon'}]

我想按他们的'name' 属性对该列表进行排序。这很容易做到:

dei.sort(key=lambda d: d['name'])

现在,因为 Python 的字母排序是 ASCII 驱动的,所以结果会是

[{'name': u'Creon'}, {'name': u'Thor'}, {'name': u'Œdipus'}]

虽然我希望 Œdipus 在 Creon 和 Thor 之间。

this suggestion 之后,我使用 PyICU 的 collator.getSortKey() 函数(我们将其重命名为 sortKey() 以提高可读性),它在字符串列表 strings 上以这种方式工作:

strings.sort(key=sortKey)

我的问题是:因为无论如何我都无法修改sortKey() 函数,我如何使用它根据某些属性对更复杂的对象(这里是字典)列表进行排序?

目前我发现的唯一方法是在一个单独的列表中提取字典的值,对其进行排序,然后实现一个自定义的 compare(a, b) 函数,根据 a 的索引返回 -1、0 或 1和b 在单独的列表中,并使用此compare() 函数调用sort()

names = sorted([d['name'] for d in dei], key=sortKey)

def compare(a, b):
    if names.index(a) < names.index(b):
        return -1
    elif names.index(a) > names.index(b):
        return 1
    else:
        return 0

results = dei.sort(key=lambda d: d['name'], cmp=compare)

我觉得不太优雅。

【问题讨论】:

  • 问题不是关键。问题是你不同意 python 的字母顺序。如果那个 'ae' 符号出现在你的语言中的 'c' 之后,你可以使用本地化吗?否则,您必须提供比较函数,告诉它按什么顺序对字母进行排序。但是仅仅在几个确切的词上提供比较功能似乎是短视的。
  • 是的,字母排序是依赖于语言的,这就是我想使用 PyICU 的原因,它可以为任何语言精确地实现它。

标签: python sorting dictionary pyicu


【解决方案1】:

您可以使用自己的密钥在内部调用具有正确值的getSortKey

>>> import icu
>>> dei = [{'name': u'Thor'}, {'name': u'Œdipus'}, {'name': u'Creon'}]
>>> collator = icu.Collator.createInstance()
>>> dei.sort(key=lambda x: collator.getSortKey(x['name']))
>>> dei
[{'name': 'Creon'}, {'name': 'Œdipus'}, {'name': 'Thor'}]

【讨论】:

  • 哦,嘘*,它...有效:-o 这是我尝试的第一件事之一,但我在 pdb 中尝试过,出于任何原因,它不接受 lambda 中的 collator ( global name 'collator' is not defined)。我花了一段时间才发现问题只出在 pdb 中,而我……完全忘记了再次测试最简单的解决方案。谢谢! (让我感到羞耻!)
猜你喜欢
  • 1970-01-01
  • 2012-05-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2010-11-15
  • 1970-01-01
相关资源
最近更新 更多