温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

json和pickle数据序列化和反序列化

发布时间:2020-07-08 13:22:44 来源:网络 阅读:282 作者:leiwenbin627 栏目:编程语言

json序列化

info = {
    
'name':'alex',
    
'age':22
}

f = 
open("test.txt",'w')
f.write(
str(info)) #把一个字典转换成字符串 从内存存到硬盘的过程叫序列化
f.close()

import json
info = {
    
'name':'alex',
    
'age':22
}

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

import json
info = {
    
'name':'alex',
    
'age':22
}
f = 
open("test.txt","w")
json.dump(info,f)

info[
"age"]=21
json.dump(info,f) #一般只dump一次,因为3.x版本只能load一次,dump多次没意义

f.close()

 

json反序列化

f = open("test.txt",'r')
data = 
eval(f.read())
f.close()
print(data['age'])

import json
f = 
open("test.txt",'r')
data = json.loads(f.read()) 
#反序列化loads
print(data['age'])

import json
f = 
open("test.txt",'r')
#data = json.load(f) #等于data= json.loads(f.read()) 会报错 3.X只能load一次
for line in f:
    
print(line)

 

pickle序列化

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

info = {
    
'name':'alex',
    
'age':22,
    
'func':sayhi
}

f = 
open("test.txt",'wb')
#print(pickle.dumps(info))
f.write(pickle.dumps(info)) #pickle可以序列化所有的数据
f.close()

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

info = {
    
'name':'alex',
    
'age':22,
    
'func':sayhi
}
f = 
open("test.txt","wb")
pickle.dump(info,f) 
# 等于f.write(pickle.dumps(info))
                    #pickle.dump(
对象,文件)
f.close()

 

pickle反序列化
import pickle
def sayhi(name):
    
print("hello2,",name)

f = 
open("test.txt",'rb')
data = pickle.loads(f.read()) 
#反序列化loads pickle只能用在python里面,java不认
print(data["func"]("alex")) #反序列化只要函数名一样就可以,序列化的是整个的数据对象

import pickle
def sayhi(name):
    
print("hello2,",name)
f=
open("test.txt",'rb')
data = pickle.load(f) 
#等于data= pickle.loads(f.read())
print(data["func"]("alex"))

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI