python序列化与反序列化(json、pickle)

1.什么是序列化&反序列化?

序列化:将字典、列表、类的实例对象等内容转换成一个字符串的过程。

反序列化:将一个字符串转换成字典、列表、类的实例对象等内容的过程

PS:Python中常见的数据结构可以统称为容器。序列(如列表和元组)、映射(如字典)以及集合(set)是三类主要的容器。

场景一:我们在python中将一个功能给另外一段程序使用,怎么给?

方法一:功能存到文件,然后另一个python程序再从文件里读出来。

场景二:现在反过来怎么把读出来的文件字符串转换成字典?

方法二:eval()函数:将字符串str当成有效的表达式求值并返回计算结果,但存在风险,将str转换成python中的数据结构,推荐使用反序列化。

序列化就是从dic变成str(dic)的过程,反序列化就是从str(dic)变成dic的过程。

2.为什们要使用序列化?

  序列化的目的:

    1.以某种存储形式使自定义对象持久化(比如从内存存到硬盘)

    2.将对象从一个地方传递到另一个地方

    3.使程序更具维护性

序列化的2个模块:

  json:用于字符串(str)和python数据类型间(比如字典、列表)进行转换

  pickle:用于python特有的类型和python的数据类型间转换

3.json

Json是一种轻量级的数据交换格式,基于ECMAScript的一个子集。Python3中可以使用json模块来对json数据进行编解码.

python本质:字符串,字符串中的值用双引号,包含了2个函数:

  python对象->json:json.dumps(python对象)

  json->python对象:json.loads(json字符串)

json.dumps():对数据进行编码,就是将mysql里的数据字符串或二进制的形式存储到硬盘。

dumps:输出到终端的操作方法,也就是把一个类型变量转换成str
dump:文件操作的方法,具体的操作json.dump(dict,open(‘test‘,‘w‘))

json.loads():对数据进行解码,将抽象的数据内容(python对象)转换成字符串。

json.load和json.loads是反序列化输出的一个结果,dump和dumps是序列化输出终端或文件中去.

python对象(基本的数据类型):int、float、str、list、tuple、dict

需求:序列化,将字典info转换成字符串,存到test1.txt文件中。

ex1:用dumps()函数序列化,通过f.write()写入test1.txt文件。

import json
info={
    ‘name‘:‘wendy‘,
    ‘age‘:22
}
f=open("test1.txt",‘w‘)
#json.dumps(info)把一个字典info转换成字符串,从内存存到硬盘的过程叫序列化
#序列化dumps函数不可以序列化,只能处理简单的跨平台数据交互
f.write(json.dumps(info))f.close()

ex2:用dump()函数序列化,直接json.dump()写入test1.txt文件。

import json
info={
    ‘name‘:‘wendy‘,
    ‘age‘:22
}
f=open("test1.txt",‘w‘)
#等于f.write(json.dumps(info))
json.dump(info,f)
f.close()

4.pickle

pickle的load、loads和dump、dumps的使用操作,先来说下,pickle和json的差异:

 4.1 pickle和json都可以实现序列化和反序列化的操作。

 4.2 在写入文件的时候,pickle是以加密的方式写入的。在打开文件的时候,‘wb’是以二进制的形式写入。

 4.3 pickle可以对类创建的对象进行反序列化输入到文件中。

pickle模块的4个功能:dump(序列化,存)、dumps、loads(反序列化,读)、load

import pickle
class ABC:
    a=10
    def __init__(self,m,n):
        self.m=m
        self.n=n

abc=ABC(1,2)
res=pickle.dumps(abc) #pickle可序列化任意类型,比如:序列化类实例
back_res=pickle.loads(res)print(res)
print(back_res)
print(back_res.a)
#结果显示
b‘\x80\x03c__main__\nABC\nq\x00)\x81q\x01}q\x02(X\x01\x00\x00\x00mq\x03K\x01X\x01\x00\x00\x00nq\x04K\x02ub.‘
<__main__.ABC object at 0x000001D7A0B31048>

原文地址:https://www.cnblogs.com/wendyw/p/11803688.html

时间: 2024-10-07 10:32:30

python序列化与反序列化(json、pickle)的相关文章

Python序列化与反序列化-json与pickle

Python序列化与反序列化-json与pickle 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.json的序列化方式与反序列化方式 1>.json序列化 1 #!/usr/bin/env python 2 #_*_coding:utf-8_*_ 3 #@author :yinzhengjie 4 #blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90

6.python序列化功能之json&pickle

json模块是个非常重要的模块,可以实现任何语言之间跨平台的数据交换,还可以实现一些比较简单的数据类型的持久化.(这里的持久化就是说,把python内部一些比较简单的数据类型,比如说像字符串,列表,元组,字典之类的数据类型,转换为json字符串的标准格式,保存到硬盘中.) json模块常用函数: json.dumps():将python以字典为主的数据类型,包括(列表,元组,等)转换为json字符串. json.loads():将json字符串转换为python可识别的数据类型. json.du

python序列化与反序列化——json与pickle

一.定义 序列化是指将对象从内存中取出来写入存储区,如txt文件中,反序列则相反. 二. 应用场景 跨平台数据传输: 保留上一次运行程序时对对象的修改 三. 模块和函数 1. json dumps().dump()(序列化) loads().load() (反序列化) 2. pickle dumps().dump()(序列化) loads().load ()(反序列化) 四.  应用案例 1. pickle 1 import pickle 2 3 info = {"lyrics": &

python类库32[序列化和反序列化之pickle]

一 pickle pickle模块用来实现python对象的序列化和反序列化.通常地pickle将python对象序列化为二进制流或文件. python对象与文件之间的序列化和反序列化: pickle.dump() pickle.load() 如果要实现python对象和字符串间的序列化和反序列化,则使用: pickle.dumps() pickle.loads() 可以被序列化的类型有: * None,True 和 False; * 整数,浮点数,复数; * 字符串,字节流,字节数组; * 包

Jackson序列化和反序列化Json数据完整示例

Jackson序列化和反序列化Json数据 Web技术发展的今天,Json和XML已经成为了web数据的事实标准,然而这种格式化的数据手工解析又非常麻烦,软件工程界永远不缺少工具,每当有需求的时候就会出现各种类库,框架以及工具来解决这些基础的问题,Jackson就是这些工具中的一个,使用这个工具开发者完全可以从手工结束Json数据的重复劳动中解放出来.使用Jackson首先需要下载相应的类库,如下的Maven dependency列出了完整的POM dependency. 1 <dependen

C#序列化及反序列化Json对象通用类JsonHelper

当今的程序界Json大行其道.因为Json对象具有简短高效等优势,广受广大C#码农喜爱.这里发一个序列化及反序列化Json对象通用类库,希望对大家有用. public class JsonHelper { #region 对象类型序列化为json 字符 /// <summary> /// 对象类型序列化为json 字符 /// </summary> /// <typeparam name="T">实体类型</typeparam> ///

Newtonsoft.Json.4.5.0 序列化与反序列化json字符串使用方法总结

在VS里下载安装: Json.NET 5.0.6 http://www.nuget.org/packages/Newtonsoft.Json/5.0.6 反序列化json字符串为List: json字符串如下: 1 {"docs": [{ 2 "uid": 2629577, 3 "nickname": "枕边疯电台", 4 "is_v": "true", 5 "category

python序列化与反序列化(json与pickle)

在python中,序列化可以理解为将python中对象的编码格式转换为json(pickle)格式的字符串,而反序列化可以 理解为将json(pickle)格式的字符串转换为python中对象的编码格式 举一个简单的例子,我们在vmvare环境下编写python程序,然后需要临时走开一下,但是我们又不想把这个vmvare关闭,这个时候我们可以选择挂机,这样我们再回来继续操作时候,就可以直接恢复到走之前的状态,那么我们之前编写的代码及vmvare的状态是保存在哪里了呢,实际上是保存在文件当中来了,

Python—序列化和反序列化模块(json、pickle和shelve)

什么是序列化 我们把对象(或者变量)从内存中变为可存储或者可传输的过程称为序列化.在python中为pickling,在其他语言中也被称之为serialization,marshalling,flattening等等.即序列化之后就可以将内存中的程序内容写入硬盘或者通过网络传输到其他机器上去.反序列化的过程则相反:将硬盘中的内容变为可以在内存中运行的程序的过程称为反序列化. Json模块 # encoding:utf-8 # 通过序列化和反序列化将内容存储到文件 import json json