我希望能够在全局范围内对字典进行排序。
我经常发现自己写的代码是这样的:
things_to_evaluate = {
'thing 1': lambda: Thing(property = 'a'),
'thing 2': lambda: Thing(property = 'b'),
...
}
...
for k, v in things_to_evaluate.iteritems():
thing = v()
result[k] = thing.process(something)
在我的例子中,字典语法是一种方便的方式来指定我想尝试的一堆实验。现在,我想让结果按照我指定的顺序显示。
我知道这是一件很糟糕的事情,我知道散列和无序集合以及 OrderedDict 的存在和一切。
不过,如果我可以选择只是为了我自己的方便,用一行代码覆盖一些原始函数并使它所有的命令都有序,后果就该死了。
那么,有谁知道这样做的方法吗?
最佳答案
您不能这样做,至少不能将源代码破解为您最喜欢的 Python 实现并重新构建它。 (而且,如果您最喜欢的实现是 CPython,那么这将是一项巨大的工作量,因为 OrderedDict
不仅不是内置的,它甚至没有 C 实现——尽管这可能会改变在 3.5.)
当然,您可以将名称 dict
重新绑定(bind)到 collections.OrderedDict
,全局(在您的模块中)或 super 全局(在内置函数中),但是不会影响文字字典显示、字典推导、返回字典的内置代码(其中包括构造类和对象 __dict__
的 type
函数和解释器代码处理 **kwargs
) 等
您可以发明您自己的方式来编写OrderedDict
显示和理解,并使用带有 AST 转换器的导入 Hook 将它们转换为对 OrderedDict 的调用
构造函数。我相信 OrderedDict
显示是 MacroPy
附带的示例之一,并且扩展它以处理理解也不应该太难。但是如果没有类似的东西,你要做的最好的是:
from collections import OrderedDict as o
things_to_evaluate = o(
('thing 1', lambda: Thing(property = 'a')),
('thing 2', lambda: Thing(property = 'b')),
...
)
……或者:
def o(*args):
return OrderedDict(zip(args[::2], args[1::2]))
things_to_evaluate = o(
'thing 1', lambda: Thing(property = 'a'),
'thing 2', lambda: Thing(property = 'b'),
...
)
关于python - 全局使 Python 字典有序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27007493/