json与pickle

json

json是进行程序数据类型的序列化与反序列化的模块之一。利用它可以进行不同平台,不同程序下的数据交换或者是程序暂时保存数据的一种方法。下面看一看json的用法:

 1 #json_序列化.py
 2 import json
 3 dic={
 4     "id":"123456",
 5     "name":"Jack",
 6     "country":"China"
 7     }
 8 date=json.dumps(dic)
 9 with open("demo.txt","w") as f:
10     f.write(date)
11
12 #json_反序列化.py
13 import json
14 with open("demo.txt","r") as f:
15     dic1=json.loads(f.read())
16 print(dic1["name"])

上面展示了两个文件的内容,第一个文件是将一个字典序列化成字符串(使用dumps()方法),然后写入一个文件(demo.txt)。第二个文件是将demo.txt中的内容读取出来,然后用loads()方法将其反序列化可以执行的那个字典对象,并且打印出字典的“name”的内容。

其实除了dumps()和loads()两个方法之外,json还有两个更简单的方法:dump()和load()。下面演示用法:

 1 #json_序列化2.py
 2 import json
 3 dic={
 4     "id":"123456",
 5     "name":"Jack",
 6     "country":"China"
 7     }
 8 with open("demo.txt","w") as f:
 9     date=json.dump(dic,f)
10
11
12
13 #json_反序列化2.py
14 import json
15 with open("demo.txt","r") as f:
16     dic1=json.load(f)
17 print(dic1["name"])

对比一下就知道,dump()和load()是将dumps()和loads()以及文件的读写操作进行的封装。

pickle

pickle同样拥有json的上述四种方法,并且用法一模一样,在这里我就不做演示。但是pickle的功能更加强大。json只能够序列化一些比较简单的数据对象,如列表,字典等等。而pickle则还可以序列化函数,类等复杂对象。

下面演示一下pickle怎样序列化和反序列化一个函数。

 1 #pickle_序列化.py
 2 import pickle
 3 #定义函数hello
 4 def hello(name):
 5     print("hello",name)
 6 #定义列表,把hello也存进去
 7 dic1={
 8     "name":"Mark",
 9     "func":hello
10     }
11 with open("demo.txt","wb") as f:
12     pickle.dump(dic1,f)
13
14 #pickle_反序列化.py
15 import pickle
16 #######################
17 def hello(name):
18     print("hello",name)
19 #######################
20 with open("demo.txt","rb")as f:
21     dic2=pickle.load(f)
22 dic2["func"]("Jack")

上面同样展示了两个文件的内容注意。要注意以下的问题:

1.当涉及到函数,类等的序列化和反序列化的时候,在打开文件的时候都要以二进制的形式打开,注意展示中的“wb”,“rb”

2.如果要使反序列化出来的函数可以再新文件里执行的话,必须要把前面定义好的函数的源代码复制到新文件里(注意pickle_反序列化.py中的两排#行内的内容),否则将无法运行,如果没有#号内的内容的话,程序会报错:AttributeError: Can‘t get attribute ‘hello‘ on <module ‘__main__‘ from ‘D:/Users/LENOVO/PycharmProjects/Myfirstflask/about_json反.py‘>

3.可以对复制过来的函数的源代码进行更改,只需要保证函数名与序列化时所用的函数名一致即可,更改后如果调用该函数,则按照更改后的函数执行(当然这种更改必须是有必要的)

作者:彭前超

时间:2017/6/13 19:45

时间: 2024-08-07 13:45:19

json与pickle的相关文章

序列化的两个模块(json和pickle)

到底什么是序列化(picking)呢? 我们把变量从内存中变成可存储或传输的过程称之为序列化 序列化之后,就可以把序列化后的内容写入磁盘,或者通过网络传输到别的机器上. 反过来,把变量内容从序列化的对象重新读到内存里称之为反序列化,即unpickling json和pickle json和pickle模块,两个都是用于序列化的模块 json #json 是通用的,可以在各种语言里进行交互,只是一个简单的序列化方法#json把python对象转化成字符串,仅限于简单的数据类型,例如列表,字典,元组

python模块(json和pickle模块)

json和pickle模块,两个都是用于序列化的模块 • json模块,用于字符串与python数据类型之间的转换 • pickle模块,用于python特有类型与python数据类型之间的转换 两个模块,都提供了dumps,dump,loads,load 4个功能 1 import json 2 s = '{"key1":"value1","key2":"value2"}' # ==> 用json模块将字符串转化成其他

day5 常用模块json和pickle

json 和 pickle json和pickle是用于字符串序列化和反序列化的过程,我们在存储和使用的时候,经常把列表存入文件,读取的时候我们还想以列表的形式读取.就需要使用json和pickle.json是支持所有的接口,pickle是python自己内置的接口. 用于序列化的两个模块 (1)json,用于字符串和python数据类型间进行转换 (2)pickle,用于python特有的类型和python的数据类型间进行转换 Json模块提供了四个功能:dumps.dump.loads.lo

json、pickle\shelve模块讲解

json.pickle模块讲解 见我前面的文章:http://www.cnblogs.com/itfat/p/7456054.html shelve模块讲解(超级好用~!) json和pickle的模块只允许dump和load一次,而shelve可以支持多次. shelve模块是一个简单的k,v将内存数据通过文件持久化的模块,可以持久化任何pickle可支持的python数据格式 执行这段代码以后会生成三个文件: 然后我们再把它读取出来:

python序列化模块json和pickle

序列化相关 1. json 应用场景: json模块主要用于处理json格式的数据,可以将json格式的数据转化为python的字典,便于python处理,同时也可以将python的字典或列表等对象转化为json格式的数据,便于跨平台或跨语言进行数据交互 功能: Json模块提供了四个功能:dumps.dump.loads.load Python 编码为 JSON 类型转换对应表: Python JSON dict object list, tuple array str string int,

Python基础-json和pickle模块

一 .序列化是指把内存里的数据类型转变成字符串,以使其能存储到硬盘或通过网络传输到远程,因为硬盘或网络传输时只能接受bytes 把字符串转化成内存数据类型 叫做反序列化 json 和 pickle 二. 只是把数据类型转化成字符串存到内存里的意义 json.dumps  json.loads 1.把你的内存数据通过网络共享给远程其他人 2.定义了不同语言的交互规则 a.纯文本,坏处,不能共享复杂的数据类型 b.xml,坏处,占用空间大 c.json,简单,可读性好 三.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

json与pickle模块

Python-19 1. json与pickle模块 什么是序列化和反序列化 序列化:是将内存中的数据结构,转换成一种中间格式,将转化后的中间格式存储到硬盘,或者基于网络传输 反序列化:是将硬盘中或者网路中传过来的中间格式,转换成内存中的数据结构 2. 序列化和反序列化有什么用 将状态通过中间格式存储到硬盘,可以保存程序的运行状态 数据可以跨平台交互,不同的编程语言,通过序列化成中间格式就可以互相交互 存到硬盘的文本文件都是字符串,再次使用时,需要将硬盘中的数据转化成以前的数据类型状态 3. j

python-时间模块,random、os、sys、shutil、json和pickle模块

一.time与datetime模块 time模块: 时间戳:表示的是从1970年1月1日00:00:00开始按秒计算的偏移量,返回类型为float类型 格式化时间字符串(Format String) 结构化的时间(struct_time):struct_time元组共有9个元素(年月日时分秒,一年中的第几周,一年中的第几天,夏令时) # print(time.time())#1533962144.060534 # print(time.localtime())#time.struct_time(

Python常用模块之json、pickle、random、hashlib、collections

1.json和pickle json用于字符串和Python数据类型间进行转换pickle用于python特有的类型和python的数据类型间进行转换json和pickle均提供了四种方法dumps,dump,loads,load ##json dumps() ##转换成字符串 loads() ##将json编码的字符串再转换为python的数据结构 dump() ##转换成字符串并存存储到文件中 load() ##从数据文件中读取数据,并将json编码的字符串转换为python的数据结构 >>