Django rest_framework中PrimaryKeyRelatedField疑惑点解决

Django rest_framework中PrimaryKeyRelatedField疑惑点解决
CSDN话题挑战赛第2期
参赛话题:学习笔记

; 案例:以项目表、接口表、用例表、配置表为例

模型类

项目模型类

class Projects(BaseModel):
    name = models.CharField('项目名称', max_length=200, unique=True, help_text='项目名称')
    leader = models.CharField('负责人', max_length=50, help_text='项目负责人')
    tester = models.CharField('测试人员', max_length=50, help_text='项目测试人员')
    programmer = models.CharField('开发人员', max_length=50, help_text='开发人员')
    publish_app = models.CharField('发布应用', max_length=100, help_text='发布应用')
    desc = models.CharField('简要描述', max_length=200, null=True, blank=True, default='', help_text='简要描述')

    class Meta:
        db_table = 'tb_projects'
        verbose_name = '项目信息'
        verbose_name_plural = verbose_name
        ordering = ('id',)

    def __str__(self):
        return self.name

接口模型类

class Interfaces(BaseModel):
    name = models.CharField('接口名称', max_length=200, unique=True, help_text='接口名称')
    project = models.ForeignKey('projects.Projects', on_delete=models.CASCADE,
                                related_name='interfaces', help_text='所属项目')
    tester = models.CharField('测试人员', max_length=50, help_text='测试人员')
    desc = models.CharField('简要描述', max_length=200, null=True, blank=True, help_text='简要描述')

    class Meta:
        db_table = 'tb_interfaces'
        verbose_name = '接口信息'
        verbose_name_plural = verbose_name
        ordering = ('id',)

    def __str__(self):
        return self.name

用例模型类

class Testcases(BaseModel):
    name = models.CharField('用例名称', max_length=50, unique=True, help_text='用例名称')
    interface = models.ForeignKey('interfaces.Interfaces', on_delete=models.CASCADE,
                                  help_text='所属接口')
    include = models.TextField('前置', null=True, help_text='用例执行前置顺序')
    author = models.CharField('编写人员', max_length=50, help_text='编写人员')
    request = models.TextField('请求信息', help_text='请求信息')

    class Meta:
        db_table = 'tb_testcases'
        verbose_name = '用例信息'
        verbose_name_plural = verbose_name
        ordering = ('id',)

    def __str__(self):
        return self.name

配置模型类

class Configures(BaseModel):
    name = models.CharField('配置名称', max_length=50, help_text='配置名称')
    interface = models.ForeignKey('interfaces.Interfaces',
                                  on_delete=models.CASCADE,
                                  related_name='configures',
                                  help_text='所属接口')
    author = models.CharField('编写人员', max_length=50, help_text='编写人员')
    request = models.TextField('请求信息', help_text='请求信息')

    class Meta:
        db_table = 'tb_configures'
        verbose_name = '配置信息'
        verbose_name_plural = verbose_name
        ordering = ('id',)

    def __str__(self):
        return self.name

需求1:获取接口的列表数据时,需要输出项目名称;创建接口时需要传递项目的id

🔥🔥🔥特别注意1:

当使用PrimaryKeyRelatedField进行反序列输入操作时,要指定查询集,目的是进行校验

🔥🔥🔥特别注意2:

序列化和反序列化操作时,当从表获取父表的数据,序列化字段定义只能用2种方法project和project_id:
interfaces_obj.project_id
interfaces_obj.project.id

🔥🔥🔥特别注意3

PrimaryKeyRelatedField:在进行反序列输入时,传递的参数是id,但是在序列化输入完成后转化为模型对象了,所以在创建数据时需要处理下,

怎么处理?
1.可以在调用create()方法前对validated_data进行处理,
2.或者在对字段校验前调用to_internal_value(data)方法处理,在字段进行校验前最开始执行的方法

序列化器类设计

class InterfaceSerializer(serializers.ModelSerializer):
    project=serializers.StringRelatedField(read_only=True,label='项目名称',help_text='项目名称')
    project_id=serializer.PrimaryKeyRelatedField(queryset=Projects.objects.all(),label='项目id',help_text='项目id',)
    class Meta:
        model=Interfaces
        fields=['update_time']
        extra_kwargs={
            "update_time":{
                "format":"%Y年%m月%d日 %H:%M:%S"
            },
            "create_time":{
                "read_only":True,
                "format": "%Y年%m月%d日 %H:%M:%S"
            }
        }

    def to_internal_value(self,data):
        response=super().to_internal_value(data)
        response['project_id']=response.get('project_id').id
        return response

    def to_internal_value(self,data):
        response=super().to_internal_value(data)
        response['project']=response.pop('project_id')
        return response

需求2:获取接口下的所有用例数据

🔥🔥🔥特别注意4

接口表和用例表的映射关系为一对多
当主表获取从表的数据是,默认使用模型类名小写_set
当从表的外键字段中设置了related_name选项时,需要用related_name指定的名称

class TestcaseNameSerializer(ModelSerializer):
    class Meta:
        model=Testcases
        fields=['id','name']

class InterfaceTestcaseSerializer(ModelSerializer):
    testcases_set=TestcaseNameSerializer(label='接口下的用例',
                                     help_text='接口下的用例',
                                     read_only=True,
                                     many=True)
    class Meta:
        model=Interfaces
        fields=['testcases_set']

需求3:获取接口下的所有配置数据

class InterfaceConfigureSerializer(ModelSerializer):
    class Meta:
        model=Configures
        fields=['id','name']

class InterfaceConfigureSerializer1(ModelSerializer):
    configures=InterfaceConfigureSerializer(many=True,read_only=True)

    class Meta:
        model=Interfaces
        fields=['configures']

视图设计

    @action(methods=['GET'],detail=True)
    def configs(self,request,*args,**kwargs):
        response=super().retrieve(request,*args,**kwargs)
        response.data=response.data.get('configures')
        return response

    @action(methods=['GET'],detail=True)
    def testcases(self,request,*args,**kwargs):
        response=super().retrieve(request,*args,**kwargs)
        response.data=response.data.get('testcases_set')
        return response

Django rest_framework中PrimaryKeyRelatedField疑惑点解决

Original: https://blog.csdn.net/YZL40514131/article/details/127147204
Author: 敲代码敲到头发茂密
Title: Django rest_framework中PrimaryKeyRelatedField疑惑点解决



相关阅读

Title: 有效解决OSError: libcusparse.so.11: cannot open shared object file: No such file or directory

无论是OSError: libcusparse.so.11,还是OSError: libcusparse.so.10,都可以用这套流程解决,一样的思路!

首先说结论:出现这种错误,要么是path没设置好,要么是cuda版本不对不包含libcusparse.so.11文件。

如果是path没设置好,其中要注意,path不仅要在terminal设置好,还要修改文件~/.bashrc里的几个export PATH。

如果是cuda版本不对不包含libcusparse.so.11文件,那就得remove current cuda,然后install new cuda。

之前我在terminal运行.py文件,会报错OSError: libcusparse.so.11,发现是我的path没设置好。在terminal设置好path之后,可以正常在terminal运行.py文件,但是竟然无法在debug时正常运行!!!每当我选择debugging的时候,又报错OSError: libcusparse.so.11,明明在terminal上已经可以正常运行,怎么回事呢???

尝试了几十种方法,google看github、stackoverflow,百度看csdn、知乎,都看麻了。终于在pyG官方团队的github issues几百个评论中梳理拼凑出了最终正确答案,真是功夫不负有心人,凌晨2点的我在那一刻太开心了!!!

以下是解决OSError: libcusparse.so.11的流程,分为 步骤1、步骤2

步骤1:在terminal设置好几个path

小tips:大家一定要学会用locate寻找文件,超级方便!我遇到的好多难缠的bug,都是依靠locate命令定位摸索出来最终解决方法的。

$ locate libcusparse.so.11

locate命令会输出文件所在位置,如下所示:

$ locate libcusparse.so.11
/data/myname/local/cuda-11.6/targets/x86_64-linux/lib/libcusparse.so.11
/data/myname/local/cuda-11.6/targets/x86_64-linux/lib/libcusparse.so.11.7.2.124

复制targets之前的路径/data/myname/local/cuda-11.6,用来之后设置path。每个人这段路径可能都不太一样,一般这段路径是/usr/local/cuda,总之需要按照你的targets之前的路径来!!!

我的路径比较特殊,因为实验室很多人共用服务器,每个人都各自按照名字存的,所以和一般路径不一样,可能你的也不一样!!!

如果你的targets之前的路径是/usr/local/cuda,就可以直接copy下面的4个path设置代码。

否则一定要把/usr/local/cuda替换成你的targets之前的路径!!!比如我要替换成/data/myname/local/cuda-11.6才正确,不能盲从,要依靠之前locate命令找到的文件位置来确定路径!

$ export PATH=/usr/local/cuda/bin:$PATH
$ echo $PATH
$ export CPATH=/usr/local/cuda/include:$CPATH
$ echo $CPATH
$ export LD_LIBRARY_PATH=/usr/local/cuda/lib64:$LD_LIBRARY_PATH
$ echo $LD_LIBRARY_PATH
$ export DYLD_LIBRARY_PATH=/usr/local/cuda/lib:$DYLD_LIBRARY_PATH
$ echo $DYLD_LIBRARY_PATH

到这里已经可以在terminal顺利运行.py文件不报错了,但是还没有完!!想要debugging顺利还需要继续下面的步骤2!!!

步骤2: 修改文件~/.bashrc里的几个export PATH

$ locate .bashrc

locate命令会输出文件所在位置,如下所示:

$ locate .bashrc
/home/myname/.bashrc

在文件末尾添加以下3个path:

注意如果你的targets之前的路径是/usr/local/cuda,就可以直接copy下面的3行path设置。

否则一定要把/usr/local/cuda替换成你的targets之前的路径!!!比如我要替换成/data/myname/local/cuda-11.6才正确,这里的path也不能盲从,也要依靠之前locate命令找到的文件位置来确定路径!

export PATH=/usr/local/cuda/bin:$PATH
export LIBRARY_PATH=/usr/local/cuda/lib64:$LIBRARY_PATH
export LD_LIBRARY_PATH=/usr/local/cuda/lib64:$LD_LIBRARY_PATH

至此,完成了 步骤1与步骤2,就完全设置好了,不论是terminal运行.py文件,还是debugging,都不会再报错。完结撒花~

Original: https://blog.csdn.net/little_cute/article/details/124766123
Author: 骄傲的计算机科学家
Title: 有效解决OSError: libcusparse.so.11: cannot open shared object file: No such file or directory

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/287506/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • Scratch 3 矢量编辑器——“临摹”一只哆啦A梦

    利用Scratch来制作一些小作品,常常需要到网上去找图片,而网上下载的图片一般都是 位图,往往存在两个问题: 图片不够清晰,当图片放大…

    Python 2022年11月12日
    085
  • 重温Python基础——变量

    哈喽兄弟们,今天我们来复习下变量。 首先尝试在一个hello_world.py文件中使用变量,在文件开头添加一行代码,并对第二行代码进行修改,如下所示: message=&quot…

    Python 2023年2月3日
    025
  • 基于gunicorn部署flask项目

    文章目录 * – + * 1、WSGI协议 * 2、gunicorn介绍 * 3、gunicorn安装 * 4、gunicorn使用 * – 4.1 基于F…

    Python 2023年1月1日
    038
  • 你评论,我赠书~【TFS-CLUB社区 第9期赠书活动】〖HTML5+CSS3+JavaScript从入门到精通(微课精编版)(第2版)〗等你来拿

    文章目录 ❤️‍🔥 赠书活动 – 《Python从入门到精通(微课精编版)》 ❤️‍🔥 编辑推荐 ❤️‍🔥 抽奖方式与截止时间 ❤️‍🔥 赠书活动 → 获奖名单 ; ❤…

    Python 2023年2月5日
    036
  • python如何读取txt里面的数据

    当我们在用python时可能会遇到想要把txt文档里的数据读取出来然后进行绘图,那么我们要怎么才能够将txt里的数据读取出来呢? 假设有txt文本如下: 要读取上述文本数据,您可以…

    Python 2023年1月10日
    018
  • 事务的ACID特性

    技术是为了解决问题而生的,通过事务我们可以解决以下问题: 多个操作不是一个整体操作,出现了部分执行成功的情况,导致数据的状态不一致问题(原子性) 一组操作只有部分完成,没有全部完成…

    Python 2023年1月31日
    023
  • python点亮led_用Python点亮led灯

    我正试着用我的钢琴和Python来点亮我的dotstar led灯带!在 我从键盘上得到我需要的信息,然后我尝试用python打开它。唯一的问题是,这是一个巨大的延迟。如果我一次按…

    Python 2023年1月21日
    025
  • python玩转modbus

    1. modbus协议简介 Modbus协议是一项应用层报文传输协议,包括ASCII / RTU / TCP三种报文类型,协议本身不定义物理层,只定义了控制器能够认识和使用的 消息…

    Python 2022年12月25日
    059
  • 第十章:django模型类(二)

    一、定义模型类 1.定义 2.生成迁移文件 3.同步数据库 二.测试模型类 1.增 方式一: 方式二: 2.查 基本查询 过滤查询 3.删 方法一: 方法二: 4.改 方法一: 方…

    Python 2022年12月27日
    035
  • Matplotlib绘图-第一回:Matplotlib初相识

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

    Python 2023年1月14日
    074
  • python基础-集合的常用操作

    {} 集合是一种无序不可重复的序列;集合常用于对两个列表的交并差处理; 集合没有任何获取元素的方法,只用作处理列表或元组的临时数据类型,不适合数据的存储和传输。 利用内置函数set…

    Python 2023年2月3日
    018
  • Git使用详解(图文+代码):Git分支

    Git分支不过如此 * – 前言 – + 什么是分支 + 分支的新建与合并 + * 分支的新建与切换 * 分支的合并 * 遇到冲突时的分支合并 * 分支的管…

    Python 2023年2月6日
    017
  • 【宝藏级】全网最全的Pandas详细教程(2万字总结)

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

    Python 2022年8月19日
    081
  • 【python接口测试】requests库安装和导入

    模块说明 requests是使用Apache2 licensed 许可证的HTTP库。 用python编写。 比urlib2模块更简洁。 Request支持HTTP连接保持和连接池…

    Python 2022年12月25日
    033
  • 强化学习实战:表格型Q-Learning玩井字棋(二)开始训练!

    在 强化学习实战 | 表格型Q-Learning玩井字棋(一)搭个框架 中,我们构建了以Game() 和 Agent() 类为基础的框架,本篇我们要让agent不断对弈,维护Q表格…

    Python 2022年10月6日
    0106
  • 使用matplotlib让你的数据更加生动(三)

    1 引言 在上一节中我们介绍了使用matplotlib进行数据可视化的几种表现方法,包括折线图、散点图、饼状图以及柱状图等, 今天我们来继续学习matplotlib的高级用法,主要…

    Python 2023年1月14日
    026
最近整理资源【免费获取】:   👉 程序员最新必读书单  | 👏 互联网各方向面试题下载 | ✌️计算机核心资源汇总