(我在这里使用python2)
比如说,我有一份字典的清单dei = [{'name': u'Thor'}, {'name': u'Œdipus'}, {'name': u'Creon'}]
我想按它们的'name'属性对该列表进行排序。这很容易做到:
^{pr2}$
现在,由于Python的字母排序是ASCII驱动的,结果将是[{'name': u'Creon'}, {'name': u'Thor'}, {'name': u'Œdipus'}]
而我希望阿狄浦斯在克里恩和托尔之间。在
在this suggestion之后,我使用PyICU的collator.getSortKey()函数(为了可读性,我们将其重命名为sortKey()),它在字符串的列表strings上是这样工作的:strings.sort(key=sortKey)
这里我的问题是:由于无论如何我都不能修改sortKey()函数,如何使用它根据某个属性对更复杂的对象(这里是字典)进行排序?在
目前我发现的唯一方法是在一个单独的列表中提取字典的值,对其进行排序,然后实现一个自定义的compare(a, b)函数,根据单独列表中的a和{}的索引返回−1、0或1,并使用此compare()函数调用{}: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)
我觉得不太优雅。在