Backend - Python 序列化

本文详细解释了JSON在前后端交互中的重要角色,包括如何使用JSON.stringify()和JSON.parse()进行数据转换,以及python的requests库和Django的JsonResponse在处理API数据中的应用。特别关注了JSONDecodeError的常见问题和解决方案。
摘要由CSDN通过智能技术生成

目录

一、作用1:代码块存入数据库

二、作用2:前后端传递数据

(一)前端

1. JSON.stringify()

2. JSON.parse()

(二)后端

1. json.dumps()

(1)作用

(2)写法

(3)例子

2. json.loads()

(1)作用

(2)理解

(3)json.loads() 问题:JSONDecodeError('Expecting property name enclosed in double quotes: line 1 column 2 (char 1)')

3. python 的 requests 库的 json()

(1)作用

(2)例子

(三)前后端的传值格式

1. 前端传后端时

2. 后端传前端时

三、查看对象格式


序列化:将内存中的不可持久化和传输对象,转换为可方便持久化和传输对象的过程。

一、作用1:代码块存入数据库

        将一段方法的代码块,进行序列化,完整的存入到数据库中。

        当调用数据库的这段序列化数据时,依旧可以执行这个代码块。

二、作用2:前后端传递数据

(一)前端

1. JSON.stringify()

        将一个 JavaScript 对象或值编码为json字符串。 (包成JSON)

2. JSON.parse()

        用来解析json字符串,还原由字符串包裹的JavaScript值或对象。 (解除JSON)

注意:前端转换JSON格式时,是大写的JSON

(二)后端

1. json.dumps()

(1)作用

        将 Python 对象编码为json字符串。(包成JSON)

        常用于后端向前端传递数据。

(2)写法

        使用 json.dumps(),而不是json.dump()。

        前者是字符串,后者是文件流。

(3)例子
import json
mydict = {"num": 123}
res = json.dumps(mydict) # 即可获得字串数据

2. json.loads()

(1)作用

        将json字符串解码为 Python 数据类型。(解除JSON)

        常用于后端接收前端传递的数据。

(2)理解

        例如:前端的阵列 AA ,使用 JSON.stringify() 编码  ->  得到 json 格式的值 BB ( str 格式,包裹着阵列) ->  后端接收的BB,使用 json.loads() 解码  ->  得到列表值CC。

(3)json.loads() 问题:JSONDecodeError('Expecting property name enclosed in double quotes: line 1 column 2 (char 1)')

        原因:

        json.loads() 里的值若是字串包字典,则字典中的key,必须有双引号!!无论是单引号,还是无引号,都会报错。

        解决:

        若字串里的字典格式无误,只是单引号的问题,则将单引号转换为双引号

import json 
mystr.replace("\'", "\"")  # 先将'单引号转变为"双引号
res = json.loads(mystr)

3. python 的 requests 库的 json()

(1)作用

        处理API请求返回后的数据。

(2)例子
import requests
response = requests.get('http://www.XXX.com', params=data)  # 获得API调用后得到的结果数据
res = response.json()  # 将API结果数据字串化

参考文章:Backend - requests 库(Python HTTP 库)_bound method response.json of <response [435]>-CSDN博客

(三)前后端的传值格式

1. 前端传后端时

        无论是“阵列”或是“字典”,都最好用JSON格式包裹(除了字串)。

$.ajax({
	type: 'POST',
	url: '',
	data: {
		'name': '萝卜干',  // 字串数据
		'mylist': JSON.stringify(["萝卜干", "18"]),  // 阵列数据
		'mydict': JSON.stringify({"name":"萝卜干", "age":"18"}),  // 字典数据
	},
	success: function (res) {
        console.log('data=', res.data)
    }
});

2. 后端传前端时

        一般用JsonResponse。

        若后端不考虑采用JsonResponse或者HttpResponse,则在前端ajax处加一属性:dataType:'json' 。其中,dataType是设置数据返回的类型。

        若设置了dataType:'json' ,则前端统一把后端回传的data数据类型看成JSON格式(既可以是JSON字串,也可以是JSON对象),所以后端可不考虑采用JsonResponse还是HttpResponse。若是JSON对象,前端需要用JSON.parse()处理。

        若不设置dataType,则前端默认自动识别后端回传的所有数据类型。       

JsonResponse相关知识可参考另一篇文章:Backend - Django JsonResponse & HttpResponse-CSDN博客

三、查看对象格式

使用网上工具:http://json.parser.online.fr/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值