python - 反向 OrderedDict 类型错误

标签 python python-3.x dictionary reverse

我有一个有序的字典,我试图以相反的顺序遍历它,基本上是从最后插入的(键,值)开始。

dicts = OrderedDict()
...
for key, value in reversed(dicts.items()):

当我将 PyCharm 与 Python 3.5.1 一起使用时,上面的代码工作正常,但是当我将它放在 codefights 上时,使用他们的 Python 3 解释器(不确定确切的版本),我得到以下 for 循环实现的错误:

TypeError: argument to reversed() must be a sequence

为什么会发生此错误,我该如何解决?

最佳答案

根据 the docs , OrderedDict.items() 仅支持 reversed 从 3.5,所以我希望它是旧版本。

解决它的一种方法是先转换为列表:

for key, value in reversed(list(dicts.items())):
     ...

NB:根据评论,dicts.items() 应该是内存高效的,但是 list(dicts.items()) 会肯定会创建一个长度为 dicts 中项目数的新列表。大多数情况下这应该没问题,但对于非常大的 dicts 这将看到 O(N) 内存使用命中,这可能很重要。

关于python - 反向 OrderedDict 类型错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42814840/

相关文章:

python - 在程序使用太多内存之前停止程序

python - 列出目录中的类 (Python)

python - 将循环输出中的所有数字相乘

python - 如何提取特定标题后的 HTML 表格?

python - 列表/字典数据操作 - 删除重复项

python - 从 Counter 对象中提取字典

c# - 使用 HTML5 GUI 进行跨平台桌面开发

python - 图像数据的 numpy 形状的维度顺序是什么?

python - Python 的 Tkinter 字段为空白

Java:按分数对 ID 进行排序