zoukankan      html  css  js  c++  java
  • python模块之shelve

    shelve模块是一个简单的k,v将内存数据通过文件持久化的模块,可以持久化任何pickle可支持的python数据格式

    shelve对pickle进行了封装,允许你dump多次,并且顺序不会乱。所以,能用shevel就用shevel,不能用就用pickle,pickle不能用再用json。

    序列化:

    import shelve
    
    f = shelve.open('shelve_test')  # 打开一个文件
    
    names = ["alex", "rain", "test"]
    info = {'name':'alex','age':22}
    
    f["names"] = names  # 持久化列表
    f['info_dic'] = info
    
    f.close()
    

    反序列化:

    import shelve
    
    d = shelve.open('shelve_test')  # 打开一个文件
    
    print(d['names'])
    print(d['info_dic'])
    
    #del d['test'] #还可以删除
    

    代码示例:

    # 对pickle进行了封装,允许你dump多次,并且顺序不会乱。
    
    import shelve
    
    
    f = shelve.open('shevel_test')  # 打开一个文件
    
    info = {'name': 'alex', 'age': 22}
    names = ['alex', 'rain', 'test']
    
    f['names'] = names
    f['info_dic'] = info
    
    f.close()  # 也是存的一推乱码
    
    with shelve.open('shevel_test') as f:
        print(f)  # <shelve.DbfilenameShelf object at 0x1032374a8>
        print(f.keys())  # KeysView(<shelve.DbfilenameShelf object at 0x101f37400>)
        print(list(f.keys()))  # ['names', 'info_dic']
        print(f.items())  # ItemsView(<shelve.DbfilenameShelf object at 0x101f37438>)
        print(f.get('names'))  # ['alex', 'rain', 'test']
        print(f.get('info_dic'))  # {'name': 'alex', 'age': 22}
        f['names'] = ['Rain', 'Ann', 'Jack'] # ['Rain', 'Ann', 'Jack']
        print(f.get('names'))
  • 相关阅读:
    awk去重以某列重复的行
    awk 统计文件中按照某列统计某列的和(sum)
    使用jdk压缩war包
    histoty显示时间戳
    awk统计文件中某关键词出现次数
    Jbox帮助文档,默认的属性含义
    net之session漫谈及分布式session解决方案
    StackExchange.Redis 基本使用 (一) (转)
    Sql Server 表创建以及Ef浅谈
    数据验证(自定义特性)
  • 原文地址:https://www.cnblogs.com/lshedward/p/10003532.html
Copyright © 2011-2022 走看看