(十四)json、pickle与shelve模块
任何语言,都有自己的数据类型,那么不同的语言怎么找到一个通用的标准?
比如,后端用Python写的,前端是js,那么后端如果传一个dic字典给前端,前端肯定不认。
所以就有了序列化这个概念。
什么是序列化?
我们把对象(变量)从内存中变成可存储或传输的过程称之为序列化,在Python中叫pickling。
序列化之后,就可以把序列化后的内容写入磁盘,或者通过网络传输进行前后端交互。
反过来,把变量内容从序列化的对象重新读到内存里称之为反序列化,即unpickling。
json、pickle模板都可以实现序列化和反序列化,而我们知道的eval则是反序列化。
json.dumps():将Python对象通通转为字符串
import json
a = 11 #---->'11'
s = 'hello' #---->"hello"------>'"hello"'
l = [1,2] #---->'[1,2]'
dic = {'name':'nick'} #---->{"name":"nick"}----->'{"name":"nick"}' print(json.dumps(a))
print(json.dumps(s))
print(json.dumps(l))
print(json.dumps(dic))
结果:
11 #这四个结果都是字符串
"hello"
[1, 2]
{"name": "nick"}
json.dumps()实际干的两件事:
1.把这个数据中的所有的单引号变为双引号(有单引号就改为双引号,没有就不动)
2.把这个数据变为字符串(在最外面加一对单引号)
json.loads():将字符串转为Python对象(与eval相似)
所以,用json现实文件存储:
import json dic = {'name':'nick'}
str_dic = json.dumps(dic) #转为字符串
f_write = open('123.txt','w')
f_write.write(str_dic) f_read = open('123.txt','r')
data = f_read.read()
data = json.loads(data) #转回字典
print(type(data))
print(data)
结果:
<class 'dict'>
{'name': 'nick'}
json
如果我们要在不同的编程语言之间传递对象,就必须把对象序列化为标准格式,比如XML,但更好的方法是序列化为JSON,因为JSON表示出来就是一个字符串,可以被所有语言读取,也可以方便地存储到磁盘或者通过网络传输。JSON不仅是标准格式,并且比XML更快,而且可以直接在Web页面中读取,非常方便。
注意,只有符合json标准格式规范的字符串,才能被解析。在字符串中,json只认双引号,如下
123.txt:
{"name": "nick"} with open('123.txt','r') as f_read:
res = f_read.read()
res = json.loads(res)
print(type(res))
print(res) 结果:<class 'dict'>
{'name': 'nick'} 123.txt:
{'name': "nick"} #单引号不符合json的标准格式 with open('123.txt','r') as f_read:
res = f_read.read()
res = json.loads(res)
print(type(res))
print(res) 结果:报错
pickle
pickle和json的用法几乎一样,只是json是将Python对象转为字符串去存储或传输,而pickle是将Python对象转为字节去存储或传输,所以pickle适用的数据类型更多,比如类、对象。但是这样的需求场景很少,所以一般来说,我们还是用json。
用pickle现实文件存储:
import pickle
dic = {'name':'nick'}
byte_dic = pickle.dumps(dic)
print(byte_dic)
with open('aaa.txt','wb') as f_write: #由于是byte,所以这里要+b
f_write.write(byte_dic) with open('aaa.txt','rb') as f_read:
date = f_read.read()
print(type(date))
date = pickle.loads(date)
print(type(date))
print(date)
结果:
b'\x80\x03}q\x00X\x04\x00\x00\x00nameq\x01X\x04\x00\x00\x00nickq\x02s.'
<class 'bytes'>
<class 'dict'>
{'name': 'nick'}
用eval内置方法可以将一个字符串转成python对象
用eval现实文件存储:
dic = {'name':'nick','age':20}
f_write = open('123.txt','w')
f_write.write(str(dic)) #写入时直接f_write.write(dic)是报错的,必须转为str f_read = open('123.txt','r')
data = f_read.read()
print(type(data)) #读取是字符串
data = eval(data) #eval转为字典
print(type(data))
print(data)
结果:
<class 'str'>
<class 'dict'>
{'age': 20, 'name': 'nick'}
不过,eval方法是有局限性的,对于普通的数据类型,json.loads和eval都能用,但遇到特殊类型的时候,eval就不管用了,所以就要用json。
用json.dumps()将字典转为字符串是序列化,用json.loads()将字符串转回字典是反序列化
用pickle.dumps()将字典转为字节是序列化,用pickle.loads()将字节转回字典是反序列化
用str()将字典转为字符串是序列化,用eval()将字符串转为字典也是反序列化
shelve
最后,简单了解一下shelve模板,shelve和json、pickle属于同一类,也是用于数据存储和传输。
shelve是将pickle模板再进一步封装,目的就是方便我们使用,可以直接把文件当做一个字典来读和写,也就是直接操作键值对
shelve模块只有一个open函数,返回类似字典的对象,可读可写;key必须为字符串,而值可以是python所支持的数据类型
import shelve #写
f = shelve.open(r'abc.txt') #返回一个类似字典的文件对象
f['name'] = 'nick' #插入键值对
f['info'] = {'age':20,'num':123321} #value是一个字典
f.close() f = shelve.open(r'abc.txt') #读
print(f['info']['age']) #直接当做一个字典来读,二级字典
print(f['name'])
(十四)json、pickle与shelve模块的更多相关文章
- python基础--json,pickle和shelve模块
一.JSON &pickle 用于序列化的两个模块 json,用于字符串 和 python数据类型间进行转换 字符串必须是双引号,不能是单引号 pickle,用于python特有的类型 和 ...
- python pickle 和 shelve模块
pickle和shelve模块都可以把python对象存储到文件中,下面来看看它们的用法吧 1.pickle 写: 以写方式打开一个文件描述符,调用pickle.dump把对象写进去 dn = {'b ...
- python json、 pickle 、shelve 模块
json 模块 用于序列化的模块 json,用于字符串 和 python数据类型间进行转换 Json模块提供了四个功能:dumps.dump.loads.load #!/usr/bin/env pyt ...
- os常用模块,json,pickle,shelve模块,正则表达式(实现运算符分离),logging模块,配置模块,路径叠加,哈希算法
一.os常用模块 显示当前工作目录 print(os.getcwd()) 返回上一层目录 os.chdir("..") 创建文件包 os.makedirs('python2/bin ...
- 第九节:os、sys、json、pickle、shelve模块
OS模块: os.getcwd()获取当前路径os.chdir()改变目录os.curdir返回当前目录os.pardir()父目录os.makedirs('a/b/c')创建多层目录os.remov ...
- python的pickle和shelve模块
python中用于序列化的模块总结 目录 pickle模块 shelve模块 xml模块 pickle模块 介绍 Pickle的问题和所有其他编程语言特有的序列化问题一样,就是它只能用于Python, ...
- 19-[模块]-json/pickle、shelve
1.序列化? 序列化是指把内存里的数据类型转变成字符串,以使其能存储到硬盘或通过网络传输到远程,因为硬盘或网络传输时只能接受bytes (1)把字典保存到文件 data = { 'roles': [ ...
- json&pickle数据序列化模块
用于序列化的模块 json,通用的序列化方式,序列化成为str类型,支持所有语言识别,序列化的数据具有局限性. pickle,python的所有数据类型都可以被序列化,序列化为bites格式,只适用于 ...
- json pickle xml shelve configparser
json:# 是一种跨平台的数据格式 也属于序列化的一种方式pickle和shevle 序列化后得到的数据 只有python才可以解析通常企业开发不可能做一个单机程序 都需要联网进行计算机间的交互 J ...
随机推荐
- Day2 列表list
list 列表 list是Python内置的一种数据类型, 是一种有序的集合, 可以随时添加或删除其中的元素,可以包含不同数据类型的元素.可以作为元素被别的list包含 . nam ...
- JavaSE04-Switch&循环语句
1.Switch 格式: 1 switch (表达式) { 2 case 1: 3 语句体1; 4 break; 5 case 2: 6 语句体2; 7 break; 8 ... 9 default: ...
- 回文数字(Palindrome Number)
总时间限制:1000ms 内存限制: 65536kB 描述 给出一系列非负整数,判断是否是一个回文数.回文数指的是正着写和倒着写相等的数. 输入 一行,一个01字符串. 输出 若干行,每行是一个非负整 ...
- Spring Data JPA 基础第二篇
主要调用工具类JpaUtils类 package cn.itcast.utils;import javax.persistence.EntityManager;import javax.persist ...
- SpringBoot从入门到精通教程(六)
之前学了,这么多东西 thyemeaf .MyBatis 还有 配置文件等等,今天我们就来做一个小案例 CRUD,程序员的必备 项目结构 pom.xml <!-- mybatis 相关依赖 -- ...
- 你真的理解了java单例模式吗?讲别人都忽略的细节!
前言:老刘这篇文章敢做保证,java的单例模式讲的比大多数的技术博客都要好,讲述别人技术博客都没有的细节!!! 1 java单例模式 直接讲实现单例模式的两种方法:懒汉式和饿汉式,单例模式的概念自己上 ...
- 老吕教程--01后端Node.js框架搭建(安装调试KOA2)
今天开始从零搭建后端框架,后端框架基于Koa2,通过Typescript语言编写. 在写后端框架之前,自己也了解过Express,感觉Koa2更加灵活,由于有多年后端研发经验,所以采用Koa2,简单敏 ...
- 干掉 powerdesigner,设计数据库表用它就够了
最近有个新项目刚过完需求,正式进入数据库表结构设计阶段,公司规定统一用数据建模工具 PowerDesigner.但我并不是太爱用这个工具,因为它的功能实在是太多了,显得很臃肿,而平时设计表用的也就那么 ...
- [leetcode]109. Convert Sorted List to Binary Search Tree链表构建二叉搜索树
二叉树的各种遍历方式都是可以建立二叉树的,例如中序遍历,就是在第一步建立左子树,中间第二步建立新的节点,第三步构建右子树 此题利用二叉搜索树的中序遍历是递增序列的特点,而链表正好就是递增序列,从左子树 ...
- 关于IP的相关计算
不论是考研还是考各种计算机类的证,大家或多或少都会遇到网络部分的一种题型,大体的归类就是以下几种: 已知一个IP是192.XX.XX.XX,子网掩码是255.255.255.0,那么它的网络地址是多少 ...