(我在这里使用 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 之间。
按照这个建议,我使用 PyICU 的collator.getSortKey()
函数(让我们重命名它以提高可读性),它在字符串sortKey()
列表上以这种方式工作:strings
strings.sort(key=sortKey)
我的问题是:由于sortKey()
无论如何我都无法修改该函数,我如何使用它根据某些属性对更复杂的对象(此处为字典)列表进行排序?
目前我发现的唯一方法是在单独的列表中提取字典的值,对其进行排序,然后实现一个自定义函数,根据单独列表的索引和在单独列表中compare(a, b)
的索引返回 -1、0 或 1 ,然后调用这个功能:a
b
sort()
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)
我觉得这不是很优雅。