概念:
  序列化 -- 其他数据类型转换成一个字符串数据类型
  反序列化 -- 字符串转换成其他数据类型
  序列 -- 字符串
必须要转换成字符串的场景:
  往文件里面写数据的时候只能写字符串,不能写字典的
  网络传输的时候只能传bytes,字典也不能直接转换成bytes
可以用到的模块:
  json 非常重要的一个模块,非常非常
  通用的序列化格式,不仅仅是局限于python,优点就是很通用
  只有很少的一部分数据类型可以序列化,局限性比较大
  pickle 仅次于json
  所有的python的数据都可以序列化
  问题在于,pickle序列化的内容只有python可以理解
  而且,反序列化依赖代码本地存在,不存在则无法解析
  shelve python3 里面新加的,特点是好操作,但是实用性就一般
  有个序列化句柄,很方便使用读写直接操作
   新加的,存在一些小问题


json '{""}' json  
  可转:
    数字 字符串 列表 字典 元祖
  不可转:
    集合
  特殊改变:  
    会将字符串改成双引号,字典里面的单引号就会改成双
  元祖的序列化会被变成列表,本身是元祖的序列后再反序列化便不会来元祖就变成列表了
  直接写内存里面的操作
  序列化方法:dumps
  反序列化方法:loads
 import json
dic = {"k1":"v1"}
print(type(dic),dic) # <class 'dict'> {'k1': 'v1'}
strd = json.dumps(dic)
print(type(strd),strd) # <class 'str'> {"k1": "v1"}
dicd = json.loads(strd)
print(type(dicd),dicd) # <class 'dict'> {'k1': 'v1'}
  往文件里面写的操作
    一次性写进去一次性读出来
    要不每次写一行,每次读一行,不然会报错
 # dump 往文件里面写
import json
dic = {"k1":"v1"}
f = open("fff","w",encoding="utf-8")
json.dump(dic,f)
f.close() # load 从文件读
f = open("fff")
res = json.load(f)
f.close()
print(type(res),res)

pickle
  用法同jons,提供dump,load,dumps,loads方法
  但是pickle序列化后会变成tyles类型,无法看出来源内容但是不影响你其他操作
  因为是bytes类型,因此文件操作需要用wb,rb的类型进行操作
  pickle可以做任何任何数据类型,可以对集合进行序列化反序列化
  比jons还要有一点,他可以分别dump load的


 # shelve 只提供一个open方法,通过key可以写入或者获取到内容
import shelve
f = shelve.open("shelve_file")
f["key"] = {"int":10,"float":9.5,"string":"sda"}
f.close() import shelve
f1 = shelve.open("shelve_file")
exiting = f1["key"]
f1.close()
print(exiting) # writeback 不设置的话是没办法修改文件的
# 不设置无法感知到修改,但是设置这个会对运行造成一定的资源占用和影响
import shelve
f1 = shelve.open('shelve_file')
print(f1['key'])
f1['key']['new_value'] = 'this was not here before'
f1.close() f2 = shelve.open('shelve_file', writeback=True)
print(f2['key'])
f2['key']['new_value'] = 'this was not here before'
f2.close()
												

day23 序列化模块的更多相关文章

  1. day23 Pyhton学习 昨日回顾.re模块.序列化模块

    一.昨日回顾 #__file__查看当前文件所在的绝对路径 #time 时间模块 time.time 获取当前时间戳时间 字符串->time.strptime->结构化->mktim ...

  2. python常用模块(模块和包的解释,time模块,sys模块,random模块,os模块,json和pickle序列化模块)

    1.1模块 什么是模块: 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文 ...

  3. sys模块和序列化模块

    import sysprint(sys.version) #查看当前pycharm版本print(sys.path )#返回模块的搜索路径print(sys.platform )#返回操作系统的版本p ...

  4. day 20 - 1 序列化模块,模块的导入

    序列化模块 首先我们来看一个序列:'sdfs45sfsgerg4454287789sfsf&*0' 序列 —— 就是字符串序列化 —— 从数据类型 --> 字符串的过程反序列化 —— 从 ...

  5. python之序列化模块、双下方法(dict call new del len eq hash)和单例模式

    摘要:__new__ __del__ __call__ __len__ __eq__ __hash__ import json 序列化模块 import pickle 序列化模块 补充: 现在我们都应 ...

  6. 4-20模块 序列化模块 hashlib模块

    1,模块,py文件就是模块,py之所以好用就是模块多. 2,模块的分类: 1,内置模块,python 安装时自带的模块 2,扩展模块,别人写好的,需要安装之后,可以直接使用.itchat微信模块, b ...

  7. Python内置模块之序列化模块

    序列化模块 json dumps loads dump load pickle dumps loads dump load shelve json 1: dumps/loads import json ...

  8. 序列化模块— json模块,pickle模块,shelve模块

    json模块 pickle模块 shelve模块 序列化——将原本的字典.列表等内容转换成一个字符串的过程就叫做序列化. # 序列化模块 # 数据类型转化成字符串的过程就是序列化 # 为了方便存储和网 ...

  9. python 常用模块(一): os模块,序列化模块(json模块 pickle模块 )

    1.os模块 2.序列化模块:(1)json模块 和 pickle模块 一.os模块 os.path.abspath: (1)把路径中不符合规范的/改成操作系统默认的格式 import os path ...

随机推荐

  1. GIT 管理修改、删除文件

    管理修改 现在,假定你已经完全掌握了暂存区的概念.下面,我们要讨论的就是,为什么Git比其他版本控制系统设计得优秀,因为Git跟踪并管理的是修改,而非文件. 你会问,什么是修改?比如你新增了一行,这就 ...

  2. WPF Blend 脑洞大开的问题:如何用Blend得到或画出一个凹槽、曲面。

    原文:WPF Blend 脑洞大开的问题:如何用Blend得到或画出一个凹槽.曲面. 目标图: 步骤一(放置一个矩形,填充蓝色): 步骤二(复制该矩形,并调整边角,填充粉红色): 第三部:让图形部分重 ...

  3. 12.4 开课三个月(phpcms安装)

    cms的样式有很多种,我们学习的是phpcms,这些cms都是大同小异,学会了一种就可以使用其它的cms. PHPCMS是一款网站管理软件.该软件采用模块化开发,支持多种分类方式,使用它可方便实现个性 ...

  4. ABP+AdminLTE+Bootstrap Table权限管理系统第三节--abp分层体系,实体相关及ABP模块系统

    返回总目录:ABP+AdminLTE+Bootstrap Table权限管理系统一期 ABP模块系统 说了这么久,还没有详细说到abp框架,abp其实基于DDD(领域驱动设计)原则的细看分层如下: 再 ...

  5. Canary机制的绕过

    目标程序下载 提取码:8ypi 1.检查程序开启了哪些安全保护机制 Canary与NX开启了 Canary机制简介 64位的canary机制,会在函数头部添加: mov rax,QWORD PTR f ...

  6. GlusterFS分布式存储学习笔记

    分布式文件系统 分布式文件系统(Distributed File System)是指文件系统管理的物理存储资源并不直接与本地节点相连,而是分布于计算网络中的一个或者多个节点的计算机上.目前意义上的分布 ...

  7. Nextcloud私有云盘在Centos7下的部署笔记

    搭建个人云存储一般会想到ownCloud,堪称是自建云存储服务的经典.而Nextcloud是ownCloud原开发团队打造的号称是“下一代”存储.初一看觉得“口气”不小,刚推出来就重新“定义”了Clo ...

  8. 集群环境删除redis指定的key

    1.说明 redis集群上有时候会需要删除多个key,就必须需要登录到每个节点上,而且有可能这个key不在这个节点,这样删除起来就比较麻烦,下面提供一种便捷方式可以实现 2.查看redis集群中的ma ...

  9. Linux实践四:ELF文件格式分析

    一.分析ELF文件头 二.通过文件头找到section header table,理解内容 三.通过section header table 找到各section 四.理解常见.text .strta ...

  10. shell脚本--数值计算

    原生bash不支持简单的数学运算,即使是最简单的加减乘除 但是,可以使用$[]和expr来实现整数运算 如果要实现小数运算,可以使用bc命令 使用$[]来实现: #!/bin/bash #文件名:te ...