zoukankan      html  css  js  c++  java
  • Python—序列化和反序列化模块(json、pickle和shelve)

    什么是序列化

    • 我们把对象(或者变量)从内存中变为可存储或者可传输的过程称为序列化。在python中为pickling,在其他语言中也被称之为serialization,marshalling,flattening等等。
    • 即序列化之后就可以将内存中的程序内容写入硬盘或者通过网络传输到其他机器上去。
    • 反序列化的过程则相反:将硬盘中的内容变为可以在内存中运行的程序的过程称为反序列化。

    Json模块

    # encoding:utf-8
    # 通过序列化和反序列化将内容存储到文件,在读取文件内容。
    import json
    jsonDict = {"name": "张三", "age": 26}
    
    # json encode ---> json编码(将python对象转换成json对象)。dict --> json str。dumps --> 序列化
    jsonDumps = json.dumps(jsonDict)  
    print jsonDumps, type(jsonDumps)  # 结果:{"age": 26, "name": "u5f20u4e09"}  <type 'str'>
    with open("information.txt", "w") as fw:
        fw.write(jsonDumps)
    
    # json decode ---> json解码(将json对象转换成python对象)。json str --> dict。loads --> 反序列化
    with open("information.txt", "r") as fr:
        jsonDumps = fr.read()         
    jsonLoads = json.loads(jsonDumps)
    print jsonLoads, type(jsonLoads)  # 结果:{u'age': 26, u'name': u'u5f20u4e09'}  <type 'dict'>
    import json
    jsonDict = {"name": "张三", "age": 26}
    
    with open(
    "information.txt", "w") as fw: json.dump(jsonDict, fw) # 相当于:1、jsonDumps=json.dumps(jsonDict) 2、fw.write(jsonDumps) with open("information.txt", "r") as fr: jsonDict = json.load(fr) # 相当于:info_dic =json.loads(fr.read()) print jsonDict, type(jsonDict) # 结果:{u'age': 26, u'name': u'u5f20u4e09'} <type 'dict'>
  • 相关阅读:
    c# 使用 Read 读取数据块
    C# TCP/IP通信,Socket通信例子
    c# virtual 关键字 虚方法
    统计图
    oauth2.0 判断接口是否允许跨域
    OI常用模板合集
    CSP2021游记
    8.16 树上问题模拟赛总结
    8.15 图论模拟赛垫底记
    8.14 字符串模拟赛总结
  • 原文地址:https://www.cnblogs.com/liuhaidon/p/11670755.html
Copyright © 2011-2022 走看看