在Django的Serializer的列表数据中剔除指定元素

news2025/1/12 7:23:23

【Python工作随笔】

提问

如何在List序列化方法中剔除不要的元素,例如在成绩中剔除0

class BasicDescriptionSubjectBoxPlotSerializer(serializers.Serializer):
    语文 = serializers.ListField(source='score_chinese')
    数学 = serializers.ListField(source='score_math')
    英语 = serializers.ListField(source='score_english')
    物理 = serializers.ListField(source='score_physics')
    化学 = serializers.ListField(source='score_chemistry')
    生物 = serializers.ListField(source='score_biology')
    历史 = serializers.ListField(source='score_history')
    地理 = serializers.ListField(source='score_geography')
    政治 = serializers.ListField(source='score_politics')

解答

要在序列化过程中剔除不需要的元素,如在成绩列表中剔除分数为0的成绩,你可以通过自定义 SerializerMethodField 来处理这些数据。这样做可以在序列化过程中对数据进行更灵活的处理。

以下是如何修改 BasicDescriptionSubjectBoxPlotSerializer 序列化器来实现这一点:

from rest_framework import serializers

class BasicDescriptionSubjectBoxPlotSerializer(serializers.Serializer):
    语文 = serializers.SerializerMethodField()
    数学 = serializers.SerializerMethodField()
    英语 = serializers.SerializerMethodField()
    物理 = serializers.SerializerMethodField()
    化学 = serializers.SerializerMethodField()
    生物 = serializers.SerializerMethodField()
    历史 = serializers.SerializerMethodField()
    地理 = serializers.SerializerMethodField()
    政治 = serializers.SerializerMethodField()

    def get_语文(self, obj):
        return [score for score in obj.score_chinese if score != 0]

    def get_数学(self, obj):
        return [score for score in obj.score_math if score != 0]

    def get_英语(self, obj):
        return [score for score in obj.score_english if score != 0]

    def get_物理(self, obj):
        return [score for score in obj.score_physics if score != 0]

    def get_化学(self, obj):
        return [score for score in obj.score_chemistry if score != 0]

    def get_生物(self, obj):
        return [score for score in obj.score_biology if score != 0]

    def get_历史(self, obj):
        return [score for score in obj.score_history if score != 0]

    def get_地理(self, obj):
        return [score for score in obj.score_geography if score != 0]

    def get_政治(self, obj):
        return [score for score in obj.score_politics if score != 0]

这里 SerializerMethodField 允许定义一个方法,该方法返回你希望包含在序列化后的数据中的值。在每个方法中,我们使用列表推导来过滤掉等于0的成绩。这样,任何为0的成绩都不会被包含在最终的序列化数据中。

需要确保序列化器的实例(obj)有正确的属性,比如 score_chinesescore_math 等,这些属性应该是包含成绩的列表。如果你的数据模型或结构与此示例不同,请相应地调整属性名。

还有一种简单直接重写 to_representation 方法。

为了在序列化过程中将数据列表中的0剔除,你可以重写to_representation方法。在这个方法中,你可以遍历每个字段的数据列表,并将0过滤掉。以下是一个示例实现:

from rest_framework import serializers

class BasicDescriptionSubjectBoxPlotSerializer(serializers.Serializer):
    语文 = serializers.ListField(source='score_chinese')
    数学 = serializers.ListField(source='score_math')
    英语 = serializers.ListField(source='score_english')
    物理 = serializers.ListField(source='score_physics')
    化学 = serializers.ListField(source='score_chemistry')
    生物 = serializers.ListField(source='score_biology')
    历史 = serializers.ListField(source='score_history')
    地理 = serializers.ListField(source='score_geography')
    政治 = serializers.ListField(source='score_politics')

    def to_representation(self, instance):
        representation = super().to_representation(instance)
        for subject in representation:
            representation[subject] = [score for score in representation[subject] if score != 0]
        return representation

to_representation 方法用于将序列化对象转换为原始数据类型(如字典)。super().to_representation(instance) 调用父类的 to_representation 方法来获取初始的序列化数据。

遍历 representation 字典中的每个科目。对每个科目的分数列表进行列表推导,排除值为0的分数。
这样每次序列化时,数据列表中的0都会被剔除。确保你的数据源中每个科目的分数列表都已经正确设置,否则可能会导致序列化失败。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2275380.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vue3(elementPlus) el-table替换/隐藏行箭头,点击整行展开

element文档链接: https://element-plus.org/zh-CN/component/form.html 一、el-table表格行展开关闭箭头替换成加减号 注:Vue3在样式中修改箭头图标无效,可能我设置不对,欢迎各位来交流指导 转变思路:隐藏箭头&…

【C++入门】详解(中)

目录 💕1.函数的重载 💕2.引用的定义 💕3.引用的一些常见问题 💕4.引用——权限的放大/缩小/平移 💕5. 不存在的空引用 💕6.引用作为函数参数的速度之快(代码体现) &#x1f4…

【题解】—— LeetCode一周小结53

🌟欢迎来到 我的博客 —— 探索技术的无限可能! 🌟博客的简介(文章目录) 【题解】—— 每日一道题目栏 上接:【题解】—— LeetCode一周小结52 30.二叉树中的链表 题目链接:1367. 二叉树中的链…

Vue方法、计算机属性及侦听器

数组变化侦测 假设我们写了一个数组&#xff0c;现在想让该数组中新增一条数据,那么如何去实现呢&#xff1f; <template><h3>数组变化侦听</h3><button click"addListHandler">添加数据</button><ul><li v-for"(item…

TIOBE编程语言排行靠前的编程语言的吉祥物

Python的吉祥物&#xff1a;小蟒蛇 Python语言的吉祥物是一只名叫"Pythonidae"&#xff08;或简称"Py"&#xff09;的小蟒蛇。这个吉祥物由Tobias Kohn设计于2005年&#xff0c;它的形象借鉴了真实的蟒蛇&#xff0c;但加入了一些可爱和友善的特点。小蟒蛇…

Linux (CentOS) 安装 Docker 和 Docker Compose

&#x1f680; 作者主页&#xff1a; 有来技术 &#x1f525; 开源项目&#xff1a; youlai-mall ︱vue3-element-admin︱youlai-boot︱vue-uniapp-template &#x1f33a; 仓库主页&#xff1a; GitCode︱ Gitee ︱ Github &#x1f496; 欢迎点赞 &#x1f44d; 收藏 ⭐评论 …

Unity热更新 之 Addressables(2) 本地/远端打包 流程测试

基础篇&#xff1a;Unity热更新 之 Addressables(1) 资源基础加载-CSDN博客 基础方法来源于唐老狮,我也是初学热更这一块&#xff0c;所有不保证步骤完全正确&#xff0c;如有不足还请斧正 目录 0.前提 1.本地打包 1.1.资源放入包 1.2.简化路径名称给出标签(如有需要的话) …

Openstack持久存储-Swift,Cinder,Manila三者之间的区别

总结不易&#xff0c;给个三连吧&#xff01;&#xff01;&#xff01; 补充&#xff1a; 文件共享存储服务Manila 在OpenStack生态系统中&#xff0c;Cinder和Manila分别提供了两种不同类型的存储服务&#xff0c;类似于传统的SAN&#xff08;存储区域网络&#xff09;和NAS&…

【TI毫米波雷达】DCA1000不使用mmWave Studio的数据采集方法,以及自动化实时数据采集

【TI毫米波雷达】DCA1000不使用mmWave Studio的数据采集方法&#xff0c;以及自动化实时数据采集 mmWave Studio提供的功能完全够用了 不用去纠结用DCA1000低延迟、无GUI传数据 速度最快又保证算力无非就是就是Linux板自己写驱动做串口和UDP 做雷达产品应用也不会采用DCA1000的…

JavaEE之线程池

前面我们了解了多个任务可以通过创建多个线程去处理&#xff0c;达到节约时间的效果&#xff0c;但是每一次的线程创建和销毁也是会消耗计算机资源的&#xff0c;那么我们是否可以将线程进阶一下&#xff0c;让消耗计算机的资源尽可能缩小呢&#xff1f;线程池可以达到此效果&a…

J-LangChain - 复杂智能链流式执行

系列文章索引 J-LangChain 入门 介绍 j-langchain是一个Java版的LangChain开发框架&#xff0c;具有灵活编排和流式执行能力&#xff0c;旨在简化和加速各类大模型应用在Java平台的落地开发。它提供了一组实用的工具和类&#xff0c;使得开发人员能够更轻松地构建类似于LangC…

《HeadFirst设计模式》笔记(上)

设计模式的目录&#xff1a; 1 设计模式介绍 要不断去学习如何利用其它开发人员的智慧与经验。学习前人的正统思想。 我们认为《Head First》的读者是一位学习者。 一些Head First的学习原则&#xff1a; 使其可视化将文字放在相关图形内部或附近&#xff0c;而不是放在底部…

springboot整合h2

在 Spring Boot 中整合 H2 数据库非常简单。H2 是一个轻量级的嵌入式数据库&#xff0c;非常适合开发和测试环境。以下是整合 H2 数据库的步骤&#xff1a; 1. 添加依赖 首先&#xff0c;在你的 pom.xml 文件中添加 H2 数据库的依赖&#xff1a; <dependency><grou…

安装rocketmq dashboard

1、访问如下地址&#xff1a; GitHub - apache/rocketmq-dashboard: The state-of-the-art Dashboard of Apache RoccketMQ provides excellent monitoring capability. Various graphs and statistics of events, performance and system information of clients and applica…

mysql中创建计算字段

目录 1、计算字段 2、拼接字段 3、去除空格和使用别名 &#xff08;1&#xff09;去除空格 &#xff08;2&#xff09;使用别名&#xff1a;AS 4、执行算术计算 5、小结 1、计算字段 存储在数据库表中的数据一般不是应用程序所需要的格式&#xff0c;下面举几个例子。 …

【批量拆分PDF】批量按页码范围拆分PDF并按页码重命名:技术难题与总结

按照页码范围拆分PDF项目实战参考&#xff1a; 【批量个性化拆分PDF】批量拆分PDF只取PDF的首页&#xff0c;批量按照文件大小来拆分PDF&#xff0c;PDF按照目录页码范围批量计算拆分分割文件PDF个性化拆分&#xff08;单个拆分&#xff0c;取首页拆分&#xff0c;按页码计算拆…

MySQL表的增删改查(基础)-上篇

目录 CRUD 新增 查询 (1)全列查询 (2)指定列查询 (3)查询时指定表达式 (4)别名 (5)去重查询 (6)排序查询 (7)条件查询 (8)分页查询 CRUD 即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写 新增 也可插入中文字符串 查询 (1)全列查…

【论文速读】| 利用大语言模型在灰盒模糊测试中生成初始种子

基本信息 论文标题: Harnessing Large Language Models for Seed Generation in Greyb0x Fuzzing 作者: Wenxuan Shi, Yunhang Zhang, Xinyu Xing, Jun Xu 作者单位: Northwestern University, University of Utah 关键词: Greyb0x fuzzing, Large Language Models, Seed g…

Linux:操作系统简介

前言&#xff1a; 在本片文章&#xff0c;小编将带大家理解冯诺依曼体系以及简单理解操作喜欢&#xff0c;并且本篇文章将围绕什么以及为什么两个话题进行展开说明。 冯诺依曼体系&#xff1a; 是什么&#xff1a; 冯诺依曼体系&#xff08;Von Neumann architecture&#xff…

为什么选择平滑样条?

为什么选择平滑样条&#xff1f; 抗噪声能力&#xff1a; 平滑样条通过引入平滑参数 λ \lambda λ&#xff0c;允许你在以下两者之间找到平衡&#xff1a; 拟合误差&#xff08;与数据的偏离&#xff09;&#xff1a;希望曲线接近数据点。光滑性&#xff08;曲线的平滑程度&a…