ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

005---json & pickle

2019-01-30 15:50:46  阅读:301  来源: 互联网

标签:f1 python j1 json 005 print 序列化 pickle


json & pickle

什么是序列化

  • 序列化是指把内存里的数据类型转变成字符串,以便使其能存储在硬盘和网络传输。因为只能接收bytes类型。

为什么要序列化

  • 持久化存储

分类

- json:用于字符串和python数据类型之间进行转换
- pickle:python特有的特性  

方法

  • dumps、dump、loads、load

使用

import json

# 最好是双引号
dic = {"name": '江子牙', 'age': 21, "性别": "男"}
print('序列化之前:', type(dic), dic)
j1 = json.dumps(dic, ensure_ascii=False)
print('序列化之后:', type(j1), j1)
dic1 = json.loads(j1)
print('反序列化:', type(dic1), dic1)

# json文件相关操作

f1 = open('1.json', 'w+', encoding='utf-8')

# 文件写入
json.dump(j1, f1, ensure_ascii=False)
f1.seek(0)
data = f1.read()
print('dump写入后的数据', data)
f1.close()

# 文件读取
f2 = open('1.json', 'r', encoding='utf-8')

res = json.load(f2)
print('load读取写入的数据', res)

json是什么

  • json是一种轻量级的数据交换格式,简洁清晰的层次结构使人易于阅读,提高网络传输效率(以bytes传输)

pickle VS json

- json
    - 优点:跨语言,体积小,
    - 缺点:支持的数据类型少,List  str  int  tuple  dict
- pickle
    - 优点:专为python设计,支持python所有的数据类型,包括函数
    - 缺点:只能在python中使用,存数数据占用空间大

标签:f1,python,j1,json,005,print,序列化,pickle
来源: https://www.cnblogs.com/xjmlove/p/10338367.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有