接口测试基础三-Python序列化和反序列化

啥是序列化?啥是反序列化?这两个词听起来优点高大上的意思,其实呢不然,很简单的可以理解为:

  • 序列化:将python的数据对象编码转换为json格式的字符串
  • 反序列化:将json格式的字符串解码为python的数据对象

在python中提供了json库,我们将json导入,查看json库下面有哪些方法:

>>> import json
>>> print (json.__all__)
[‘dump‘, ‘dumps‘, ‘load‘, ‘loads‘, ‘JSONDecoder‘, ‘JSONEncoder‘]
>>>

我们通过上面的例子可以知道json库里面常用的方法有

[‘dump‘, ‘dumps‘, ‘load‘, ‘loads‘, ‘JSONDecoder‘, ‘JSONEncoder‘]

有的小伙伴可能不知道什么是json这里有个传送门去了解下哈:https://baike.baidu.com/item/JSON/2462549?fr=aladdin

ok,那么我们接下来进行序列化的代码演示,通过json进行序列化json格式字符串,请看下面的代码:

import json

dict1={‘name‘:"fighter",
      ‘age‘:28,
      ‘address‘:‘shenzhen‘}

print (‘未序列化前的数据类型为:‘,type(dict1))
print (‘未序列化前的数据:‘,dict1)
str1 = json.dumps(dict1)   #将python数据对象序列化操作变成字符串
print (‘序列化后的数据类型为:‘,type(str1))
print (‘序列化后的数据为:‘,str1)

输出结果:

C:\Python34\python3.exe E:/Project_case/demo1.py
未序列化前的数据类型为: <class ‘dict‘>                          #-----------字典类型
未序列化前的数据: {‘address‘: ‘shenzhen‘, ‘name‘: ‘fighter‘, ‘age‘: 28}
序列化后的数据类型为: <class ‘str‘>                             #-----------字符串类型
序列化后的数据为: {"address": "shenzhen", "name": "fighter", "age": 28}

然后我们在将序列化后得到的结果反序列化操作:

import json  #导入json库

#定义字典
dict1={‘name‘:"fighter",
      ‘age‘:28,
      ‘address‘:‘shenzhen‘}

print (‘未序列化前的数据类型为:‘,type(dict1))
print (‘未序列化前的数据:‘,dict1)

#对python对象进行序列化操作
print (‘begin对python对象进行序列化操作------------>‘)
str1 = json.dumps(dict1)
print (‘序列化后的数据类型为:‘,type(str1))
print (‘序列化后的数据为:‘,str1)

#对str1进行反序列化操作
print (‘begin对str1对象进行反序列化操作------------>‘)
dict2 = json.loads(str1)
print (‘反序列化后的数据类型:‘,type(dict2))
print (‘反序列化后的数据:‘,dict2)

输出结果:

C:\Python34\python3.exe E:/Project_case/demo1.py
未序列化前的数据类型为: <class ‘dict‘>
未序列化前的数据: {‘name‘: ‘fighter‘, ‘age‘: 28, ‘address‘: ‘shenzhen‘}
begin对python对象进行序列化操作------------>
序列化后的数据类型为: <class ‘str‘>
序列化后的数据为: {"name": "fighter", "age": 28, "address": "shenzhen"}
begin对str1对象进行反序列化操作------------>
反序列化后的数据类型: <class ‘dict‘>
反序列化后的数据: {‘name‘: ‘fighter‘, ‘age‘: 28, ‘address‘: ‘shenzhen‘}

最后,我们在结合requests库,来查看一下json数据,具体代码如下:

import json,requests  #导入json库/requests库

r = requests.get(‘http://wthrcdn.etouch.cn/weather_mini?city=深圳‘)
print (r.text,‘数据类型:‘,type(r.text))

#对数据进行反序列化操作
dic = json.loads(r.text)
print (dic,‘数据类型:‘,type(dic))

查看反序列化前,正常响应结果:

{"data":{"yesterday":{"date":"18日星期日","high":"高温 23℃","fx":"无持续风向","low":"低温 17℃","fl":"<![CDATA[<3级]]>","type":"多云"},"city":"深圳","aqi":"39","forecast":[{"date":"19日星期一","high":"高温 25℃","fengli":"<![CDATA[<3级]]>","low":"低温 18℃","fengxiang":"无持续风向","type":"阵雨"},{"date":"20日星期二","high":"高温 26℃","fengli":"<![CDATA[<3级]]>","low":"低温 17℃","fengxiang":"无持续风向","type":"多云"},{"date":"21日星期三","high":"高温 21℃","fengli":"<![CDATA[3-4级]]>","low":"低温 14℃","fengxiang":"东风","type":"小雨"},{"date":"22日星期四","high":"高温 17℃","fengli":"<![CDATA[3-4级]]>","low":"低温 13℃","fengxiang":"东风","type":"小雨"},{"date":"23日星期五","high":"高温 19℃","fengli":"<![CDATA[<3级]]>","low":"低温 13℃","fengxiang":"无持续风向","type":"阴"}],"ganmao":"天气转凉,空气湿度较大,较易发生感冒,体质较弱的朋友请注意适当防护。","wendu":"23"},"status":1000,"desc":"OK"} 数据类型: <class ‘str‘>

反序列化后输出的结果:

{‘status‘: 1000, ‘desc‘: ‘OK‘, ‘data‘: {‘forecast‘: [{‘date‘: ‘19日星期一‘, ‘high‘: ‘高温 25℃‘, ‘low‘: ‘低温 18℃‘, ‘fengxiang‘: ‘无持续风向‘, ‘type‘: ‘阵雨‘, ‘fengli‘: ‘<![CDATA[<3级]]>‘}, {‘date‘: ‘20日星期二‘, ‘high‘: ‘高温 26℃‘, ‘low‘: ‘低温 17℃‘, ‘fengxiang‘: ‘无持续风向‘, ‘type‘: ‘多云‘, ‘fengli‘: ‘<![CDATA[<3级]]>‘}, {‘date‘: ‘21日星期三‘, ‘high‘: ‘高温 21℃‘, ‘low‘: ‘低温 14℃‘, ‘fengxiang‘: ‘东风‘, ‘type‘: ‘小雨‘, ‘fengli‘: ‘<![CDATA[3-4级]]>‘}, {‘date‘: ‘22日星期四‘, ‘high‘: ‘高温 17℃‘, ‘low‘: ‘低温 13℃‘, ‘fengxiang‘: ‘东风‘, ‘type‘: ‘小雨‘, ‘fengli‘: ‘<![CDATA[3-4级]]>‘}, {‘date‘: ‘23日星期五‘, ‘high‘: ‘高温 19℃‘, ‘low‘: ‘低温 13℃‘, ‘fengxiang‘: ‘无持续风向‘, ‘type‘: ‘阴‘, ‘fengli‘: ‘<![CDATA[<3级]]>‘}], ‘ganmao‘: ‘天气转凉,空气湿度较大,较易发生感冒,体质较弱的朋友请注意适当防护。‘, ‘aqi‘: ‘39‘, ‘wendu‘: ‘23‘, ‘yesterday‘: {‘date‘: ‘18日星期日‘, ‘high‘: ‘高温 23℃‘, ‘low‘: ‘低温 17℃‘, ‘fl‘: ‘<![CDATA[<3级]]>‘, ‘type‘: ‘多云‘, ‘fx‘: ‘无持续风向‘}, ‘city‘: ‘深圳‘}} 数据类型: <class ‘dict‘>

原文地址:https://www.cnblogs.com/fighter007/p/8454266.html

时间: 2024-08-30 09:49:35

接口测试基础三-Python序列化和反序列化的相关文章

接口测试基础三--python完成接口调用

前面的接口测试基础一文章有讲到,一次http接口调用,包含了httprequest(http请求)和httpresponse(http响应)两部分,要想做好接口测试,就需要对这两部分内容进行学习,再简单介绍下: 一.http request剖析 请求方法:即http请求的提交方式,一般以get和post居多 URI:请求自愿的表示,可以理解为一个请求的路径信息 协议:http协议 版本:1.1 请求正文:请求参数 请求头:告诉服务器关于客户端环境和请求正文相关的一些信息,例如浏览器版本,请求参数

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

C#三十一 序列化与反序列化

序列化又称串行化,是.NET运行时环境用来支持用户定义类型的流化的机制.其目的是以某种存储形成使自定义对象持久化,或者将这种对象从一个地方传输到另一个地方. .NET框架提供了两种串行化的方式:1.是使用BinaryFormatter进行串行化:2.使用SoapFormatter进行串行化:3.使用XmlSerializer进行串行化.第一种方式提供了一个简单的二进制数据流以及某些附加的类型信息,而第二种将数据流格式化为XML存储:第三种其实和第二种差不多也是XML的格式存储,只不过比第二种的X

python序列化与反序列化(json与pickle)

在python中,序列化可以理解为将python中对象的编码格式转换为json(pickle)格式的字符串,而反序列化可以 理解为将json(pickle)格式的字符串转换为python中对象的编码格式 举一个简单的例子,我们在vmvare环境下编写python程序,然后需要临时走开一下,但是我们又不想把这个vmvare关闭,这个时候我们可以选择挂机,这样我们再回来继续操作时候,就可以直接恢复到走之前的状态,那么我们之前编写的代码及vmvare的状态是保存在哪里了呢,实际上是保存在文件当中来了,

Python—序列化和反序列化模块(json、pickle和shelve)

什么是序列化 我们把对象(或者变量)从内存中变为可存储或者可传输的过程称为序列化.在python中为pickling,在其他语言中也被称之为serialization,marshalling,flattening等等.即序列化之后就可以将内存中的程序内容写入硬盘或者通过网络传输到其他机器上去.反序列化的过程则相反:将硬盘中的内容变为可以在内存中运行的程序的过程称为反序列化. Json模块 # encoding:utf-8 # 通过序列化和反序列化将内容存储到文件 import json json

python序列化与反序列化(json、pickle)

1.什么是序列化&反序列化? 序列化:将字典.列表.类的实例对象等内容转换成一个字符串的过程. 反序列化:将一个字符串转换成字典.列表.类的实例对象等内容的过程 PS:Python中常见的数据结构可以统称为容器.序列(如列表和元组).映射(如字典)以及集合(set)是三类主要的容器. 场景一:我们在python中将一个功能给另外一段程序使用,怎么给? 方法一:功能存到文件,然后另一个python程序再从文件里读出来. 场景二:现在反过来怎么把读出来的文件字符串转换成字典? 方法二:eval()函

python序列化与反序列化——json与pickle

一.定义 序列化是指将对象从内存中取出来写入存储区,如txt文件中,反序列则相反. 二. 应用场景 跨平台数据传输: 保留上一次运行程序时对对象的修改 三. 模块和函数 1. json dumps().dump()(序列化) loads().load() (反序列化) 2. pickle dumps().dump()(序列化) loads().load ()(反序列化) 四.  应用案例 1. pickle 1 import pickle 2 3 info = {"lyrics": &

python 序列化和反序列化

概念 序列化: 将对象的状态信息转换为可以存储或传输的形式的过程.就是把对象转换成字符串的过程 反序列化: 把字符串转换成python可以识别的数据类型对象的过程 应用 #数据存储 #网络传输 模块 json #通用的序列化格式 #只有少部分数据类型能通过json转换(数字,字符串,列表,字典,元组) #写文件的操作时,如果找不到ascii码的格式,就会自动转成bytes,所以要添加ensure_ascii=False的参数 #能多次写,但不能多次读 import json dic = {'k1

Python序列化与反序列化pickle

#要将Python对象作为一个文件的形式保存到磁盘,就叫序列化:#当我们需要用到这个这对象,再从磁盘加载这个对象,就叫反序列化#Python自带的pickle可以帮我们实现,pickle这个单词是咸菜的意思,咸菜耐储存,是不是很形象呀? #对象的存储分为两步:#1.将对象在内存中的数据抓取取来,转换成一个有序的文本,这一步就是序列化#2.再将文本存储到磁盘中 import pickle class Bird(object): have_feather = True reproduction_me