当前位置: 首页 > news >正文

Backend - Python 序列化

目录

一、作用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结果数据字串化

(三)前后端的传值格式

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/

http://www.lryc.cn/news/256044.html

相关文章:

  • 初级数据结构(一)——顺序表
  • 实现:切换页面切换标题,扩展 vue-router 的类型
  • 已通过考试和认证注册以及后续计划表
  • 开源计算机视觉库OpenCV详解
  • 使用pytorch查看中间层特征矩阵以及卷积核参数
  • HarmonyOS4.0从零开始的开发教程09页签切换
  • 大电流H桥电机驱动电路的设计与解析(包括自举电路的讲解,以IR2104+LR7843为例)
  • windows11 windows 11 (win11 win 11) 怎么安装 Python3 ? numpy? sounddevice? 声音信号处理库?
  • git如何配置多个远程仓库,并且进行切换
  • 计算机存储单位 + 程序编译过程
  • vue路由导航守卫(全局守卫、路由独享守卫、组件内守卫)
  • 单片机双机通信控制跑马灯
  • 微信小程序:button微信开放能力打开客服会话分享到聊天框
  • 【数据结构】——队列实现二叉树的功能
  • 【已解决】Win7虚拟机安装VMtools报错
  • 华为OD机试真题-小明找位置-2023年OD统一考试(C卷)
  • 2023.2版idea安装教程,现在jdk8已经过去式了,不同idea支持的jdk不同。升级jdk后idea也要随之升级
  • CSS3技巧36:让内容垂直居中的三种方式
  • 空间运算设备-Apple Vision Pro
  • cocos creator “TypeError: Cannot set property ‘string‘ of null
  • 简谈MySQL的binlog模式
  • Linux 环境部署RabbitMQ
  • 【1day】泛微e-office OA系统xml.php 文件 SORT_ID 参数 SQL 注入漏洞学习
  • 智能无人零售:革新零售消费体验的未来
  • 代币化对网约车区块链平台的影响
  • YOLOv7 学习笔记
  • 【51单片机系列】74HC595实现对LED点阵的控制
  • Canal笔记:安装与整合Springboot模式Mysql同步Redis
  • C++的继承语法
  • C# .NET平台提取PDF表格数据,并转换为txt、CSV和Excel表格文件