不能pickle的OrderedDict.keys()对象(Py2-bt-py3)

栏目: Python · 发布时间: 7年前

内容简介:不能pickle的OrderedDict.keys()对象(Py2-bt-py3)

一则来自django-redis的报错:TypeError: can't pickle odict_keys objects

迁移到 Python 3时遇到的一个问题,Py3中的OrderedDict.keys()返回的是一个对象:odict_keys。可以迭代的对象,但是不支持index操作,和切片操作。并且不能pickle。所以我就遇到这个坑了。不过它多了一个更新keys的功能,可以看最后的参考链接。

代码如下:

# coding:utf-8
from collections import OrderedDict

od = OrderedDict({"a": 1, "b": 2})
print(od.keys(), type(od.keys()))

od_keys = od.keys()
od.update({"c": 'the5fire'})
print(od_keys)

python2.7和Python3.6下分别运行:

➜  tmp python2.7 t_py3.py
(['a', 'b'], <type 'list'>)
['a', 'b']
➜  tmp python3.6 t_py3.py
odict_keys(['a', 'b']) <class 'odict_keys'>
odict_keys(['a', 'b', 'c'])

参考:

----EOF-----

扫码关注,或者搜索微信公众号:码农悟凡

不能pickle的OrderedDict.keys()对象(Py2-bt-py3)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

计算机和难解性

计算机和难解性

M.R 加里、D.S. 约翰逊 / 张立昂、沈泓 / 科学出版社 / 1987年 / 4.50

本书系统地介绍了NP完全性理论的概念和方法,全书共分为7章和两个附录。第一章粗略地介绍了计算复杂性的一些基本概念和NP完全性理论的意义。第二章至第五章介绍了NP完全性的基本理论和证明的方法。第六章集中研究NP难问题的近似算法。第七章概述了大量计算复杂性中的有关理论课题。 附录A收集了范围广泛、内容丰富的NP完全性和NP难的问题、附录B补充了NP问题的一些最新的进展,既有理论方面的,又有关于具体问题......一起来看看 《计算机和难解性》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

MD5 加密
MD5 加密

MD5 加密工具