day5-json和pickle序列化
#!/usr/bin/python3 import json data = {'name':'JieSen','height':175,'weight':'68KG'} #dumps到字符串 json_str = json.dumps(data) print('dumps到字符串:',json_str,'类型:',type(json_str)) #loads回来 json_dict = json.loads(json_str) print('loads回来:',json_dict,'类型:',type(json_dict))#输出: dumps到字符串: {"weight": "68KG", "height": 175, "name": "JieSen"} 类型: <class 'str'> loads回来: {'weight': '68KG', 'height': 175, 'name': 'JieSen'} 类型: <class 'dict'>
#!/usr/bin/python3 import json with open('data_json.txt','w+',encoding='utf-8') as f: json.dump(data,f) with open('data_json.txt','r') as f: data_r = json.load(f) print(data_r)
import json l1 = ["alex", 123, "eric"] l2 = ["alex", 123, 'eric'] s1 = """ ["alex", 123, "eric"] """ s2 = """ ["alex", 123, 'eric'] """ print(json.dumps(l1)) print(json.dumps(l2)) print(json.loads(s1)) print(json.loads(s2)) #这里会出错,网上说是引号要一致,暂时先这么理解吧,大家有更新的说法麻烦给说下
#!/use/bin/python3 import pickle data = {'k1':1,'k2':2} #以二进制方式打开一个文件并将数据dump保存到文件里面 with open('pickle_data.txt','wb') as f: pickle.dump(data,f) #以二进制读取方式打开文件并load加载 with open('pickle_data.txt','rb') as f: fb = pickle.load(f) print(fb)
输出:
{'k1': 1, 'k2': 2}
如果处理的不是文件,可以使用pickle.dumps和pickle.loads,例如:
data = {'name':'JieSen','height':175,'weight':'68KG'} #转换为一个字节流对象 pickle_byte = pickle.dumps(data) print(pickle_byte,'格式:',type(pickle_byte)) #从字节流中恢复对象 pickle_dict = pickle.loads(pickle_byte) print(pickle_dict,'格式:',type(pickle_dict))
输出:
b'\x80\x03}q\x00(X\x04\x00\x00\x00nameq\x01X\x06\x00\x00\x00JieSenq\x02X\x06\x00\x00\x00heightq\x03K\xafX\x06\x00\x00\x00weightq\x04X\x04\x00\x00\x0068KGq\x05u.' 格式: <class 'bytes'>
{'name': 'JieSen', 'height': 175, 'weight': '68KG'} 格式: <class 'dict'>
总结:
1.pickle序列化的是字节,而json序列化的是字符。
2.json.dump,json.load和pickle.dump,pickle.road处理的都是文件。
3.json.dumps把对象编码成json字符串
4.json.loads把已编码的 JSON 字符串解码为 Python 对象
day5-json和pickle序列化的更多相关文章
- json and pickle 序列化
前言 文件只能存储字符串.二进制,若把内存的数据对象存到硬盘 从硬盘里读取数据,里面不止是字符串的类型,因此用到了json and pickle 序列化 json序列化 作用:用于不同语言进行的数 ...
- (转)python常用模块(模块和包的解释,time模块,sys模块,random模块,os模块,json和pickle序列化模块)
阅读目录 1.1.1导入模块 1.1.2__name__ 1.1模块 什么是模块: 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代 ...
- python常用模块(模块和包的解释,time模块,sys模块,random模块,os模块,json和pickle序列化模块)
1.1模块 什么是模块: 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文 ...
- Python的json and pickle序列化
json序列化和json反序列化 #!/usr/bin/env python3 # -*- coding: utf-8 -*- __author__ = '人生入戏' import json a = ...
- (1)json和pickle序列化模块
json 和pickle 模块 json和pickle模块下都有4个功能 dumps <---> loads (序列化 <--->反序列化) dump <---> ...
- Python3 json、pickle序列化与反序列化
注意:可以dumps多次,loads只能一次,一般我们只dumps一次,loads一次,多个版本就写入多个文件 一.json序列化与反序列化: 支持各种语言数据交互,但只能处理字典,列表,集合等简单的 ...
- json和pickle序列化模块
一.json序列化模块 1.序列化:将内存数据转成字符串加以保存. 2.反序列化:将字符串转成内存数据加以读取. data = { '北京':{ '五道口':{ 'sohu':'引擎', } } } ...
- python 跨语言数据交互、json、pickle(序列化)、urllib、requests(爬虫模块)、XML。
Python中用于序列化的两个模块 json 用于[字符串]和 [python基本数据类型] 间进行转换 pickle 用于[python特有的类型] 和 [python基本数据类型]间进 ...
- json and pickle 序列化和反序列化
类似vmware虚拟机里的虚拟主机挂起操作,把当前内存拷贝成文件保存. 上面的这种操作就叫内存序列化:如下图: 有序列化就有反序列化,要把文件里的东西再恢复成字典:eval把字符串变成字典. 但是上面 ...
- python学习之day5,装饰器,生成器,迭代器,json,pickle
1.装饰器 import os import time def auth(type): def timeer(func): def inner(*args,**kwargs): start = tim ...
随机推荐
- 配置opensips经验总结
主要参考https://www.cnblogs.com/Forever-Kenlen-Ja/p/7741776.html (ubuntu),还有https://blog.csdn.net/sunyun ...
- WebAPI安全
1.Oauth Oauth2.0各语言版本公认框架https://oauth.net/code/
- iOS UI布局-回到顶部
回到顶部,是比较常用的一个效果 核心代码 在ViewDidLoad中,添加回到顶部按钮 计算偏移量,如果当前显示的内容全部向上隐藏掉,则显示“回到顶部”按钮 // // ViewController. ...
- 读书笔记_Effective_C++_条款三:尽可能使用const
const是常量的意思,它可以定义一个不可改变的量,主要用于以下几个地方: 1. 修饰变量,使之不可改变 举个例子: const int var = 3; 此时var的值就不能改变了.也正是因为con ...
- LeetCode118.杨辉三角
给定一个非负整数 numRows,生成杨辉三角的前 numRows 行. 在杨辉三角中,每个数是它左上方和右上方的数的和. 示例: 输入: 5 输出: [ [1], [1,1], [1,2,1], [ ...
- python pandas模块,nba数据处理(1)
pandas提供了使我们能够快速便捷地处理结构化数据的大量数据结构和函数.pandas兼具Numpy高性能的数组计算功能以及电子表格和关系型数据(如SQL)灵活的数据处理能力.它提供了复杂精细的索引功 ...
- CSS选择器的优先级及权重问题【CSS核心问题】及其它属性
1.CSS选择器优先级: !important >行间样式> id >class和属性选择器>标签选择器>通配符选择器 注意:[初级工程师水平] 2. ...
- Sql Server参数化查询之where in和like实现详解 [转]
文章导读 拼SQL实现where in查询 使用CHARINDEX或like实现where in 参数化 使用exec动态执行SQl实现where in 参数化 为每一个参数生成一个参数实现where ...
- yii2 modules模块配置指南
在Yii2 中模块是可以无限级嵌套的,也就是说,模块可以包含另一个包含模块的模块,我们称前者为父模块,后者为子模块, 子模块必须在父模块的yiibaseModule::modules属性中申明,例如: ...
- latex与word之间的各种转化方法
https://blog.csdn.net/communix/article/details/49965233 https://blog.csdn.net/yaoqi_isee/article/det ...