Python序列化模块JSON与Pickle

作者:springsnow 时间:2022-11-06 00:24:37 

序列化把对象(变量)从内存中变成可存储或传输的过程称之为序列化,在Python中叫pickling,在其他语言中也被称之为serialization,marshalling,flattening。

一、JSON序列化

使用json序列化能够达到跨平台传输数据的目的。

跨平台性质,它可以序列化dict/list/str/int/float/bool/None数据类型。

序列化成json文本格式。

1、json数据类型和python数据类型对应关系表:

Json类型<&mdash;&mdash;>Python类型

  • {}<&mdash;&mdash;>dict

  • []<&mdash;&mdash;>list, tuple

  • "string"<&mdash;&mdash;>str, unicode

  • 520.13<&mdash;&mdash;>int, long, float

  • true/false<&mdash;&mdash;>True/False

  • null<&mdash;&mdash;>None

2、相关函数

(2)序列化

  • 序列化成字符串:json.dumps(json_obj)

  • 序列化字符串到文件中:json.dump(json_obj, write_file, [,protocol])

(2)反序列化

  • 反序列化成对象:json.loads(json_str)

  • 从文件读流中反序列化成对象:json.load(read_file)

3、举例:

import json

struct_data = {'name': 'json', 'age': 23, 'sex': 'male'}
print(struct_data, type(struct_data))  # {'name': 'json', 'age': 23, 'sex': 'male'}
# 序列化
data = json.dumps(struct_data)
print(data, type(data))  # {"name": "json", "age": 23, "sex": "male"}

# 反序列化
data = json.loads(data)
print(data, type(data))  # {'name': 'json', 'age': 23, 'sex': 'male'}

磁盘文件操作

import json

# 序列化,写入磁盘
with open('Json序列化对象.json', 'w') as fw:
   json.dump(struct_data, fw)

# 从文件读取,反序列化
with open('Json序列化对象.json') as fr:
   data = json.load(fr)
print(data)  # {'name': 'json', 'age': 23, 'sex': 'male'}

二、Pickle序列化

pickle无法跨平台,序列化之后只有python识别。但是可以序列化Python的任意数据类型,包括函数和对象。

Json模块和picle模块都有 dumps、dump、loads、load四种方法,而且用法一样。但是序列化成二进制形式。

1、举例:

import pickle

struct_data = {'name': 'json', 'age': 23, 'sex': 'male'}
print(struct_data, type(struct_data))  # {'name': 'json', 'age': 23, 'sex': 'male'}

data = pickle.dumps(struct_data)
print(data, type( data))  # b'\x80\x03}q\x00(X\x04\x00\x00\x00nameq\x01X\x04\x00\x00\x00jsonq\x02X\x03\x00\x00\x00ageq\x03K\x17X\x03\x00\x00\x00sexq\x04X\x04\x00\x00\x00maleq\x05u.'

data = pickle.loads(data)
print(data, type(data))  # {'name': 'json', 'age': 23, 'sex': 'male'} 'dict'>

# 序列化(注意:pickle模块需要使用二进制存储,即'wb'模式存储)
with open('Pickle序列化对象.pkl', 'wb') as fw:
   pickle.dump(struct_data, fw)

# 反序列化
with open('Pickle序列化对象.pkl', 'rb') as fr:
   pickle = pickle.load(fr)
print(data)  # {'name': 'json', 'age': 23, 'sex': 'male'}

2、base64与pickle联合使用

str = 'Hello World'  # 加密前,原始数据
a = base64.b64encode(pickle.dumps(str)).decode()  # 加密
print(a) # gANYCwAAAEhlbGxvIFdvcmxkcQAu
b = pickle.loads(base64.b64decode(a.encode()))  # 解密
print(b)

来源:https://www.cnblogs.com/springsnow/p/12524129.html

标签:Python,序列化,模块,JSON,Pickle
0
投稿

猜你喜欢

  • php 深入理解strtotime函数的使用详解

    2024-05-03 15:53:03
  • Python 中的装饰器实现函数的缓存(场景分析)

    2022-07-30 01:37:08
  • Python中的Decorator装饰器的使用示例

    2023-07-02 10:37:44
  • Christopher Schmitt 谈学习CSS的益处

    2008-07-13 14:15:00
  • Pandas创建DataFrame提示:type object 'object' has no attribute 'dtype'解决方案

    2022-08-06 16:33:18
  • pycharm实现print输出保存到txt文件

    2023-05-09 22:14:20
  • python爬取指定微信公众号文章

    2021-03-29 02:34:39
  • asp显示左边的n个字符自动识别汉字的函数

    2007-09-13 12:16:00
  • python 如何去除字符串头尾的多余符号

    2021-12-29 03:17:36
  • Python @property使用方法解析

    2021-10-27 05:42:46
  • Python tensorflow与pytorch的浮点运算数如何计算

    2023-06-28 14:13:15
  • Python构建简单线性回归模型

    2021-03-22 19:58:42
  • 详解vue-router2.0动态路由获取参数

    2024-04-09 10:49:42
  • CSS实现完美垂直居中

    2007-09-22 09:29:00
  • Go语言学习笔记之错误和异常详解

    2024-02-05 11:39:15
  • JavaScript中cookie工具函数封装的示例代码

    2024-04-25 13:16:01
  • Python文本处理之按行处理大文件的方法

    2023-01-24 11:11:34
  • 30行Python代码打造一款简单的人工语音对话

    2023-03-16 18:10:19
  • 用Python写一个模拟qq聊天小程序的代码实例

    2022-04-01 10:01:42
  • 用图片做网站输入验证的构想

    2009-02-02 10:18:00
  • asp之家 网络编程 m.aspxhome.com