• python-pickle持久化存档


    那么为什么需要序列化和反序列化这一操作呢?

    便于存储。序列化过程将文本信息转变为二进制数据流。这样就信息就容易存储在硬盘之中,当需要读取文件的时候,从硬盘中读取数据,然后再将其反序列化便可以得到原始的数据。在Python程序运行中得到了一些字符串、列表、字典等数据,想要长久的保存下来,方便以后使用,而不是简单的放入内存中关机断电就丢失数据。python模块大全中的Pickle模块就派上用场了,它可以将对象转换为一种可以传输或存储的格式。

    注意:

    只能在python中使用,只支持python的基本数据类型。

    可以处理复杂的序列化语法。(例如自定义的类的方法,游戏的存档等)

    序列化的时候,是序列化了整个序列对象,而不是内存地址。

    1.保存bytes形式dumps()

    把任意对象序列化成一个bytes,然后,就可以把这个bytes写入文件,或者通过网络传输。   

    import pickle
    
    d = dict(name='Bob', age=20, score=88)
    bts=pickle.dumps(d)
    print type(bts)# 输出:<type 'str'>
    
    #加载方式,读取bytes
    bj2 = pickle.loads(bts) 
    print type(obj2)# 输出:<type 'tuple'>   
    print obj2# 输出:d {'age': 20, 'score': 88, 'name': 'Bob'}

    2.文件形式,dump,load

    直接把对象序列化后写入一个file-like Object: 

    f = open('dump.txt', 'wb') 
    pickle.dump(d, f) 
    f.close() 
    
    f = open('dump.txt', 'rb')
    d = pickle.load(f)
    f.close()
    #d {'age': 20, 'score': 88, 'name': 'Bob'}
  • 相关阅读:
    AjaxHelper 无刷新留言
    girdview 中的radiobutton 的逐行触发checkedselected事件
    .NET 新语法
    获取checkbox的值
    git 代码提交规范
    chrome的timeline中stalled问题解析
    小程序添加节流阀
    深度遍历与广度遍历
    JS 运行机制
    地址栏输入url后做了那些事情什么
  • 原文地址:https://www.cnblogs.com/onenoteone/p/12441777.html
Copyright © 2020-2023  润新知