pickle json模块
pickle --- Python 对象序列化
通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储。
通过pickle模块的反序列化操作,我们能够从文件中创建上一次程序保存的对象。
警告pickle 模块并不安全。你只应该对你信任的数据进行unpickle操作。
构建恶意的 pickle 数据来在解封时执行任意代码是可能的。
绝对不要对不信任来源的数据和可能被篡改过的数据进行解封。
在你处理不信任数据时,更安全的序列化格式如 json 可能更为适合
# 将 obj 封存以后的对象作为 bytes 类型直接返回,而不是将其写入到文件
pickle.dumps(obj, protocol=None, *, fix_imports=True, buffer_callback=None)
# 重建并返回一个对象的封存表示形式 data 的对象层级结构。 data 必须为 bytes-like object
pickle.loads(data, *, fix_imports=True, encoding="ASCII",
errors="strict", buffers=None)
>>> a = [1, 2, 3, 4]
>>>
>>> b = pickle.dumps(a) # dumps()
>>>
>>> b
b'\x80\x04\x95\r\x00\x00\x00\x00\x00\x00\x00]\x94(K\x01K\x02K\x03K\x04e.'
>>>
>>> c = pickle.loads(b) # loads()
>>> c
[1, 2, 3, 4]
# 将对象 obj 封存以后的对象写入已打开的 file object file
pickle.dump(obj, file, protocol=None, *, fix_imports=True, buffer_callback=None)
# 从已打开的 file object 文件 中读取封存后的对象,重建其中特定对象的层次结构并返回
pickle.load(file, *, fix_imports=True, encoding="ASCII",
errors="strict", buffers=None)
>>> def code():
... print('嘿嘿')
...
>>> with open('a.txt', 'wb') as fp: #dump()
... pickle.dump(code, fp)
...
>>> with open('a.txt', 'rb') as fp: #load()
... pickle.load(fp)()
...
嘿嘿
json --- JSON 编码和解码器
是一个受 JavaScript 的对象字面量语法启发的轻量级数据交换格式
Python 编码为 JSON 类型转换对应表:
Python | JSON |
---|---|
dict | object |
list, tuple | array |
str | string |
int, float, int- & float-derived Enums | number |
True | true |
False | false |
None | null |
JSON 解码为 Python 类型转换对应表:
JSON | Python |
---|---|
object | dict |
array | list |
string | str |
number (int) | int |
number (real) | float |
true | True |
false | False |
null | None |
# json.dumps 用于将 Python 对象编码成 JSON 字符串
json.dumps(obj, skipkeys=False, ensure_ascii=True,
check_circular=True, allow_nan=True, cls=None, indent=None,
separators=None, encoding="utf-8", default=None, sort_keys=False, **kw)
# 如果 ensure_ascii 是 true (即默认值),输出保证将所有输入的非 ASCII 字符转义
# 如果 ensure_ascii 是 false,这些字符会原样输出
# 如果 sort_keys 是 true(默认为 False),那么字典的输出会以键的顺序排序
>>> dic = { '张三':{'age': '16',
... 'like':'打球',},
... '李四':{'age': '19',
... 'like':'游泳',}
... }
>>>
>>> json.dumps(dic, ensure_ascii=False)
'{"张三": {"age": "16", "like": "打球"}, "李四": {"age": "19", "like": "游泳"}}'
# json.loads 用于解码 JSON 数据。该函数返回 Python 字段的数据类型
json.loads(s, *, cls=None, object_hook=None,
parse_float=None, parse_int=None, parse_constant=None,
object_pairs_hook=None, **kw)
>>> json.loads(json.dumps(dic))
{'张三': {'age': '16', 'like': '打球'}, '李四': {'age': '19', 'like': '游泳'}}
#---------
>>> dic = { '张三':{'age': '16',
... 'like':'打球',},
... '李四':{'age': '19',
... 'like':'游泳',}
... }
>>>
>>> with open('a.txt', 'w', encoding='utf-8') as fp:
... json.dump(dic, fp, ensure_ascii=False)
...
>>>
>>> with open('a.txt', 'r', encoding='utf-8') as fp:
... json.load(fp)
...
{'张三': {'age': '16', 'like': '打球'}, '李四': {'age': '19', 'like': '游泳'}}
>>>
小结:pickle模块可以连续的dump和load。每一次的dump会在结尾的地方加上一个结束标记
json模块可以连续的dump,但是结束的时候没有结束标记。
想要连续load,需要自定义结束标记,让以标记为循环的去load数据
pickle json模块的更多相关文章
- python day7: time,datetime,sys,pickle,json模块
目录 python day 7 1. time模块 2. datetime模块 2.1 date类 2.2 time类 2.3 datetime类 2.4 timedelta类 2.5 tzinfo时 ...
- pytho中pickle、json模块
pickle & json 模块 json,用于字符串 和 python数据类型间进行转换 pickle,用于python特有的类型 和 python的数据类型间进行转换 json模块提供了四 ...
- python常用模块(模块和包的解释,time模块,sys模块,random模块,os模块,json和pickle序列化模块)
1.1模块 什么是模块: 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文 ...
- python序列化: json & pickle & shelve 模块
一.json & pickle & shelve 模块 json,用于字符串 和 python数据类型间进行转换pickle,用于python特有的类型 和 python的数据类型间进 ...
- pickle和json模块
json模块 json模块是实现序列化和反序列化的,主要用户不同程序之间的数据交换,首先来看一下: dumps()序列化 import json '''json模块是实现序列化和反序列话功能的''' ...
- json模块和pickle模块的用法
在python中,可以使用pickle和json两个模块对数据进行序列化操作 其中: json可以用于字符串或者字典等与python数据类型之间的序列化与反序列化操作 pickle可以用于python ...
- 【python标准库模块四】Json模块和Pickle模块学习
Json模块 原来有个eval函数能能够从字符串中提取出对应的数据类型,比如"{"name":"zhangsan"}",可以提取出一个字典. ...
- Python第十四天 序列化 pickle模块 cPickle模块 JSON模块 API的两种格式
Python第十四天 序列化 pickle模块 cPickle模块 JSON模块 API的两种格式 目录 Pycharm使用技巧(转载) Python第一天 安装 shell 文件 Py ...
- Python全栈之路----常用模块----序列化(json&pickle&shelve)模块详解
把内存数据转成字符,叫序列化:把字符转成内存数据类型,叫反序列化. Json模块 Json模块提供了四个功能:序列化:dumps.dump:反序列化:loads.load. import json d ...
随机推荐
- 【Notes_1】现代图形学入门——计算机图形学概述
跟着闫令琪老师的课程学习,总结自己学习到的知识点 课程网址GAMES101 B站课程地址GAMES101 课程资料百度网盘[提取码:0000] 计算机图形学概述 计算机图形学是一门将模型转化到屏幕上图 ...
- Django登录使用的技术和组件
登录 ''' 获取用户所有的数据 每条数据请求的验证 成功之后获取所有正确的信息 失败则显示错误信息 ''' #登陆页面管理 def login(request): if request.method ...
- redis.conf 配置说明
redis.conf 配置项说明如下: 1. Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程 daemonize no 2. 当Redis以守护进程方式运行时,R ...
- 剑指 Offer 60. n个骰子的点数 + 动态规划 + 空间优化
剑指 Offer 60. n个骰子的点数 Offer_60 题目详情 题解分析 package com.walegarrett.offer; /** * @Author WaleGarrett * @ ...
- Java I/O流 05
I/O流·文件递归 统计该文件夹的大小 * 需求:从键盘就收一个文件夹路径,统计该文件夹的大小 package com.heima.test; import java.io.File; import ...
- mysql-canal-rabbitmq 安装部署教程
原文 1.1. 开启 MySQL 的 binlog 日志 修改 my.cnf 或 my.ini(windows), 添加配置项: # binlog 日志存放路径 log-bin=D:\env\mysq ...
- CRLF注入漏洞 -配置错误
漏洞分析参考 https://i-beta.cnblogs.com/posts/edit 什么是CRLF? CRLF 指的是回车符(CR,ASCII 13,\r,%0d) 和换行符(LF,ASCII ...
- 漫漫Java路1—基础知识3—数据类型和变量作用域以及常量
强类型语言 所有变量定义后才能使用,区别于js等弱类型语言 数据类型分类 基本类型(primitive type) 引用类型(reference type) 整数类 byte:占1字节 short:占 ...
- synchronized中锁是怎么升级的
在JDK1.6以前,使用synchronized就只有一种方式即重量级锁,而在JDK1.6以后,引入了偏向锁,轻量级锁,重量级锁,来减少竞争带来的上下文切换. 锁升级主要依赖对象头中的Mark Wor ...
- java mvc 及其缓存
使用Spring框架的好处是什么? - 轻量:Spring 是轻量的,基本的版本大约2MB. - 控制反转:Spring通过控制反转实现了松散耦合,对象们给出它们的依赖,而不是创建或查找依赖的对象们. ...