Json & pickle 数据序列化

前提:

文本文件中只能写入字符串或ascii码格式的内容。

info={‘name‘:‘zoe‘,‘age‘:18}
f=open(‘test.txt‘,‘w‘)
f.write(info)  #在文本文件中写入字典格式的内容,执行会报错。
f.closed()

变通方式将 f.write(info) 改为 f.write(str(info))。

但是这种写法比较低端。

同时,将文件通过open()读取到环境中,读取进来的还是字符串格式的。上面的操作是序列化,读取文件后的操作时反序列化。

f=open(‘test.txt‘,‘r‘)
data=f.read()
print(type(data))   #返回class ‘str‘
#想要保留数据的原本的格式,还需要将数据转化。
data_new=eval(data)
print(type(data_new))
print(data_new)

返回:

但是上面的序列化和反序列化的方式不是常规的用法。只是在我们不了解序列化模块json,pickle的时候的用法。接下来我们介绍用于序列化的两个模块。

用于序列化的两个模块

  • json,用于字符串 和 python数据类型间进行转换
  • pickle,用于python特有的类型 和 python的数据类型间进行转换

Json模块提供了四个功能:dumps、dump、loads、load

pickle模块提供了四个功能:dumps、dump、loads、load

json

实例1:

import json
info={‘name‘:‘zoe‘,‘age‘:18}
f=open(‘test.txt‘,‘w‘)
f.write(json.dumps(info))  #序列化。将info转换为字符串,写入文本文件中
f.close()
import json
f=open(‘test.txt‘,‘r‘)
data=json.loads(f.read())   #反序列化。用loads方法将字符串
print(data(type))
f.close()

实例2:

>>> import json
>>> def sayhi(name):
    print(‘hello,‘,name)

>>> info={‘name‘:‘zoe‘,‘age‘:18,‘func‘:sayhi}
>>> f=open(‘test.txt‘,‘w‘)

>>> f.write(json.dumps(info))   #函数sayhi的内存地址不是json可以序列化的参数。
Traceback (most recent call last):
  File "<pyshell#12>", line 1, in <module>
    f.write(json.dumps(info))
  File "C:\Users\Zoe\Anaconda3\lib\json\__init__.py", line 230, in dumps
    return _default_encoder.encode(obj)
  File "C:\Users\Zoe\Anaconda3\lib\json\encoder.py", line 198, in encode
    chunks = self.iterencode(o, _one_shot=True)
  File "C:\Users\Zoe\Anaconda3\lib\json\encoder.py", line 256, in iterencode
    return _iterencode(o, 0)
  File "C:\Users\Zoe\Anaconda3\lib\json\encoder.py", line 179, in default
    raise TypeError(repr(o) + " is not JSON serializable")
TypeError: <function sayhi at 0x000000000317F8C8> is not JSON serializable

所以,json只能支持简单的数据类型,如字典,列表,字符串等。——

json主要用于不同的语言之间进行数据交互。比方说java和python之间的字典的交互,类,函数等复杂的json是无法进行处理,在不同语言之间进行交互。

xml主要在不同的语言和程序之间进行数据交互,是一种标记式的语言,正在逐渐被json给取代。因为json更简洁,更清晰。json是目前主流的在不同语言之间进行数据交互的模块。

json只能处理简单的,而pickle是用来处理复杂的数据类型。

json和pickle的操作和json一模一样。

pickle

实例1:

import pickle
def sayhi(name):
    print(‘hello,‘,name)

info={‘name‘:‘zoe‘,‘age‘:18,‘func‘:sayhi}
f=open(‘test.txt‘,‘wb‘)  #以二进制方式写入文件
f.write(pickle.dumps(info))   #pickle.dump(info,f)完全等价
f.close()

反序列化:

import pickle
def sayhi(name):
    print(‘hello world‘,name)

f=open(‘test.txt‘,‘rb‘)
a=pickle.loads(f.read())  #完全等价于pickle.load(f)
print(a)
a[‘func‘](‘zoe‘)
‘‘‘如果反序列化中程序中没有sayhi()函数,则会报错。然而,在程序中有定义的同名的sayhi()函数即可读取并调用。
两个程序之间的内存地址是不能互相访问的,所以在函数序列化中,
pickle只能在python中使用。‘‘‘

小知识:

json和pickle在文件写入过程中dumps两次,会写入两次;

json和pickle在文件中loads,在3.x中只能loads一次。

在2.x中第一次dump的,可以第一次loads。但是这个不好。

所以对于同一个文件的写入和读取记住只dump一次,load一次。如果想要每个都要dump一次,则dump成不同的文件。

时间: 2024-08-25 20:15:35

Json & pickle 数据序列化的相关文章

Day4 - 迭代器&amp;生成器、装饰器、Json &amp; pickle 数据序列化、软件目录结构规范

---恢复内容开始--- 本节内容 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 作业:ATM项目开发 1.列表生成式,迭代器&生成器 列表生成式 需求:列表a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9],要求把列表里的每个值加1 1 a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 2 b = [] 3 for i in a: 4 b.append(i+1) 5 a = b 6 print(a) 普通青

Python-Day4 Python基础进阶之生成器/迭代器/装饰器/Json &amp; pickle 数据序列化

一.生成器 通过列表生成式,我们可以直接创建一个列表.但是,受到内存限制,列表容量肯定是有限的.而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了.所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间.在Python中,这种一边循环一边计算的机制,称为生成器:generator. 要创建一个generator,有很多种

Python之路-python(装饰器、生成器、迭代器、Json &amp; pickle 数据序列化、软件目录结构规范)

装饰器: 首先来认识一下python函数, 定义:本质是函数(功能是装饰其它函数),为其它函数添加附件功能        原则:        1.不能修改被装饰的函数的源代码.        2.不能修改被装饰的函数的调用方式. 1 def test(): 2 print('test') 3 print(test ) #表示是函数 4 test() #表示执行foo函数 <function test at 0x00595660>#表示的是函数的内存地址test#函数test执行结果 简单的装

Python3 json &amp;pickle 数据序列化

json 所有语言通用的信息交换格式 json.dumps()将list列表.dict字典.元组.函数等对象转换为可以存储的字符格式存入文件 json.dump(数据对象名,已以写方式打开的对象) 直接写入,省略f.write()写法 这个过程称之为"序列化" json.loads("已读文件对象")将存入的数据类型列表.字典.函数等,读出来.还原为原来的数据类型. json.load("已打开文件对象")  这个过程叫做反序列化   pickl

装饰器、生成器,迭代器、Json &amp; pickle 数据序列化

1. 列表生成器:代码例子 1 a=[i*2 for i in range(10)] 2 print(a) 3 4 运行效果如下: 5 D:\python35\python.exe D:/python培训/s14/day4/列表生成式.py 6 [0, 2, 4, 6, 8, 10, 12, 14, 16, 18] 7 8 Process finished with exit code 0 2.高阶函数 变量可以指向函数,函数的参数能接受变量,即把一个函数名当做实参传给另外一个函数 返回值中包涵

python3--json与pickle数据序列化

必读:json和pickle 可以多次jumps, 1.json适合处理简单数据,可以跨语言.跨文件: 基本方法:(比较low的方法序列化用str转换,反序列化用eval:) import json #数据序列化 info = {"name":"bokeyuan"} f = open("test.txt","w") f.write(json.dumps(info)) f.close #数据反序列化 f = open("

json —— pickle 的序列化和反序列化

前言json的序列化和反序列化 1, json 只能序列化简单的数据类型,如,列表,字典,字符串,等简单的类型,不能序列化复杂的类型. 2, json 是支持所有的语言的,多以我们跨语言的时候都是用json,(和其他语言交互) json 序列化 json的序列化 json.dumps() import jsoninfo = { 'zhang':'123', 'qing':'456'}f = open('json_wenjian','w',encoding='utf-8')f.write(json

python学习第四章之json与pickle数据序列化

1.终于学到json了,简直是万分期待 2.json序列化:json.dumps() json反序列化:json.loads() json对字典.列表.字符串起作用,可以在不同语言间进行交互. pickle只支持python语言,Java只认识json,一般是dump一次,对应的load一次 3.(1)使用json将字典的一个内容存入文本中, import json info={ 'name':'alex', 'age':22 } f=open("test.text","w&

python------Json与pickle数据序列化

一.json序列化 xml在被json取代,不同平台之间的语言转换,只能处理简单的.复杂的用pickle: pickle只能在python中用,而在Java中json也可以被识别. info = { 'name':'xiaolaizi', 'age':22 } f = open("test.text","w") f.write(str(info))------------------------------------------------ import json