zoukankan      html  css  js  c++  java
  • json模块

    json和pickle模块

    序列化:

    --把对象(变量)从内存中变成可存储或传输的过程称之为序列化

    --在Python中叫pickling,在其他语言中也被称之为serialization,marshalling,flattening。

    优点:

    1.持久保存状态:

    内存是无法永久保存数据的,当程序运行了一段时间,我们断电或者重启程序,内存中关于这个程序的之前一段时间的数据(有结构)都被清空了。
    但是在断电或重启程序之前将程序当前内存中所有的数据都保存下来(保存到文件中),以便于下次程序执行能够从文件中载入之前的数据,然后继续执行,这就是序列化。

    2.跨平台数据交互:

    序列化时不仅可以把序列化后的内容写入磁盘,还可以通过网络传输到别的机器上,如果收发的双方约定好实用一种序列化的格式,那么便打破了平台/语言差异化带来的限制,实现了跨平台数据交互。
    json数据类型和python数据类型对应关系表
    
    Json类型	Python类型
    {}	dict
    []	list
    "string"	str
    520.13	int或float
    true/false	True/False
    null	None
    --json文件进行存入硬盘的是json类型数据
    --不支持元组,集合,函数
    

    json模块:

    #数据在内存
    json.dumps() --序列化
    json.loads() --反序列化
    
    #对文件操作
    json.dump()
    json.load()
    序列化: python文件 ---》json串
    
    注意:无论数据是怎样创建的,只要满足json格式(如果是字典,则字典内元素都是双引号),就可以json.loads出来,不一定非要dumps的数据才能loads
    

    pickle模块

    Pickle序列化和所有其他编程语言特有的序列化问题一样,它只能用于Python,

    可以存储Python中的所有的数据类型,包括对象

    #数据在内存
    pickle.dumps() --序列化
    pickle.loads() --反序列化
    
    #对文件操作
    pickle.dump()
    pickle.load()
    序列化: python文件 ---》plk文件
    (注意:pickle模块需要使用二进制存储,即'wb'模式存储)
    
  • 相关阅读:
    用户管理 之 Linux 系统中的超级权限的控制
    硬件管理 之 存储设备分区操作及文件系统管理概述
    用户管理 之 Linux 用户(User)查询篇
    软件工程——需求工程
    自动装载模块
    管理内核模块
    模块功能的注册和取消
    编程实现将任意的十进制整数转换成R进制数
    数据流图分析与设计
    软件工程——系统工程
  • 原文地址:https://www.cnblogs.com/shaozheng/p/11600340.html
Copyright © 2011-2022 走看看