Url

from django.contrib import admin
from django.urls import path, re_path
from django.urls import include urlpatterns = [
re_path(r'^admin/', admin.site.urls),
re_path('^api/(?P<version>[v1|v2]\w+)/', include('app01.urls')),
]
from django.urls import path, re_path
from django.urls import include
from app01.views import account, coursehost, newspapers urlpatterns = [
re_path('login/$', account.LoginView.as_view()), re_path('course/$', coursehost.CourseView.as_view({"get": "list"})),
re_path('course/(?P<pk>\d+)/$', coursehost.CourseView.as_view({"get": "retrieve"})),
re_path(r'coursecategory/$', coursehost.CourseCategoryView.as_view({'get': 'list'})), ]

序列化

"""
* coding: utf-8 CreateTime:2019/12/18
Version: v1
DocName: account.py
Edit: Riven Effect: Course serializers SourceStorageLocation: RivenShop / app01 / views / coursehost.py
Modify and add function record:
ModifyTime:
1.
2.
Add function Time :
1.
2. """ from app01 import models
from rest_framework import serializers # Course
class CourseSerializer(serializers.ModelSerializer):
# (0, '初级'), (1, '中级'), (2, '高级') Can get value
course_type = serializers.CharField(source='get_course_type_display')
status = serializers.CharField(source='get_status_display')
level = serializers.CharField(source='get_level_display') class Meta:
model = models.Course
fields = ['id', 'name', 'course_type', 'level', 'sub_category', 'degree_course', 'course_img', 'status',
'brief', 'pub_date', 'period', 'attachment_path'] # CourseCategory
class CourseCategorySerializer(serializers.ModelSerializer):
class Meta:
model = models.CourseCategory
fields = '__all__' class CourseDetailSerializer(serializers.ModelSerializer):
# one2one/fk/choice Fk inquire
name = serializers.CharField(source='course.name')
img = serializers.CharField(source='course.course_img')
level = serializers.CharField(source='course.get_level_display') # m2m
recommend_courses = serializers.SerializerMethodField()
teachers = serializers.SerializerMethodField() # FK reverse
coursechapter = serializers.SerializerMethodField() class Meta:
model = models.CourseDetail
fields = ['id', 'hours', 'course_slogan', 'video_brief_link', 'why_study', 'what_to_study_brief',
'career_improvement', 'prerequisite', 'name', 'level', 'img', 'recommend_courses', 'teachers',
'coursechapter'] def get_recommend_courses(self, obj):
"""acquire recommend course"""
queryset = obj.recommend_courses.all()
return [{'id': row.id, 'name': row.name} for row in queryset] def get_teachers(self, obj):
"""acquire teachers all"""
obj = obj.teachers.all()
return [{'id': row.id, 'name': row.name} for row in obj] def get_coursechapter(self, obj):
"""acquire chapter all base on reverse"""
obj = obj.course.coursechapters.all() return [{'id': row.id} for row in obj]

视图

"""
* coding: utf-8 CreateTime:2019/12/17
Version: v1
DocName: account.py
Edit: Riven Effect: Supply data for Course SourceStorageLocation: RivenShop / app01 / views / Coursehost
Modify and add function record:
ModifyTime:
1.
2.
Add function Time :
1.
2. """ from app01 import models
from serializers.course import CourseCategorySerializer, CourseDetailSerializer, CourseSerializer from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework.viewsets import ViewSetMixin class CourseCategoryView(ViewSetMixin, APIView):
"""
Course main class """ def list(self, request, *args, **kwargs): ret = {"code": 1000, "data": None}
try:
queryset = models.CourseCategory.objects.all()
ser = CourseCategorySerializer(instance=queryset, many=True)
ret['data'] = ser.data
except Exception as e:
ret['code'] = 1001
ret['error'] = '获取课程失败' return Response(ret) class CourseView(ViewSetMixin, APIView): def list(self, request, *args, **kwargs):
"""
Course list Api """ ret = {'code': 1000, 'data': None}
try:
queryset = models.Course.objects.all()
ser = CourseSerializer(instance=queryset, many=True)
print(ser.data)
ret['data'] = ser.data except Exception as e:
ret['code'] = 1001
ret['error'] = '获取课程失败' return Response(ret) def retrieve(self, request, *args, **kwargs):
""" CourseDetail api """ ret = {'code': 1000, 'data': None} try:
# Acquire course id
pk = kwargs.get('pk')
# CourseDetail object
obj = models.CourseDetail.objects.filter(course_id=pk).first()
ser = CourseDetailSerializer(instance=obj, many=False)
ret['data'] = ser.data except Exception as e:
ret['code'] = 1001
ret['error'] = '获取课程详细失败' return Response(ret)

Django API接口FK ManyTo Many 模板的更多相关文章

  1. Django使用AJAX调用自己写的API接口

    Django使用AJAX调用自己写的API接口 *** 具体代码和数据已上传到github https://github.com/PythonerKK/eleme-api-by-django-rest ...

  2. 03: zabbix API接口 对 主机、主机组、模板、应用集、监控项、触发器等增删改查

    目录:Django其他篇 01: 安装zabbix server 02:zabbix-agent安装配置 及 web界面管理 03: zabbix API接口 对 主机.主机组.模板.应用集.监控项. ...

  3. 初识Django —Python API接口编程入门

    初识Django —Python API接口编程入门 一.WEB架构的简单介绍 Django是什么? Django是一个开放源代码的Web应用框架,由Python写成.我们的目标是用Python语言, ...

  4. Django FBV CBV以及使用django提供的API接口

    FBV 和 CBV 使用哪一种方式都可以,根据自己的情况进行选择 看看FBV的代码 URL的写法: from django.conf.urls import url from api import v ...

  5. Django项目:CMDB(服务器硬件资产自动采集系统)--03--03CMDB信息安全API接口交互认证

    #settings.py """ Django settings for AutoCmdb project. Generated by 'django-admin sta ...

  6. Django项目:CMDB(服务器硬件资产自动采集系统)--02--02CMDB将服务器基本信息提交到API接口

    AutoCmdb # urls.py """AutoCmdb URL Configuration The `urlpatterns` list routes URLs t ...

  7. 测开大佬告诉你:如何5分钟快速创建restful风格的API接口-使用django restframework框架

    一.思考❓❔ 1.创建API接口难吗? 软件测试工程师: 只测过API接口, 从没创建过 应该需要掌握一门后端开发语言和后端开发框架吧!? 脑容量有限,想想就可怕 2.如何创建API接口呢? 使用Dj ...

  8. day71:drf:API接口&Restful API规范&Django Rest Framework&drf中的序列化和反序列化功能

    目录 1.web应用模式 2.API接口 3.Restful API规范 4.序列化 5.Django Rest Framework 1.drf的简单介绍 2.drf的特点 3.如何安装drf 4.d ...

  9. 爬虫+django,打造个性化API接口

    简述 今天也是同事在做微信小程序的开发,需要音乐接口的测试,可是用网易云的开放接口比较麻烦,也不能进行测试,这里也是和我说了一下,所以就用爬虫写了个简单网易云歌曲URL的爬虫,把数据存入mysql数据 ...

随机推荐

  1. Delphi 开发微信公众平台 (三)- 获取微信服务器IP地址

    如果公众号基于安全等考虑,需要获知微信服务器的IP地址列表,以便进行相关限制,可以通过该接口获得微信服务器IP地址列表或者IP网段信息. 接口调用请求说明 http 请求方式: GET https:/ ...

  2. 【题解】Luogu P5283 [十二省联考2019]异或粽子

    原题传送门 看见一段的异或和不难想到要做异或前缀和\(s\) 我们便将问题转化成:给定\(n\)个数,求异或值最靠前的\(k\)对之和 我们珂以建一个可持久化01trie,这样我们就珂以求出每个值\( ...

  3. 【题解】Luogu P5294 [HNOI2019]序列

    原题传送门 题意:给你一个长度为\(n\)的序列\(A\),每次询问修改一个元素(只对当前询问有效),然后让你找到一个不下降序列\(B\),使得这两个序列相应位置之差的平方和最小,并输出这个最小平方和 ...

  4. [UOJ #393]【NOI2018】归程

    题目大意:有一张$n$个点$m$条边的图,每个边有两个属性$a_i,b_i$.有$Q$个询问,每个询问给出$v,p$,表示所有边中$b_i\leqslant p$的边会被标记,在点$v$,可以通过不被 ...

  5. jupyter notebook在 mac 使用

    1. 查看当前 conda 所拥有的环境列表 conda env list 2. 选择要进入的环境 source activate your_env_name 3. 启动 jupyter jupyte ...

  6. 处女篇:自用C#后端SqlHelper.cs类

    自用SqlHelper.cs类,此类来自软谋教育徐老师课程SqlHelper.cs! using System; using System.Collections; using System.Coll ...

  7. Actions require unique method/path combination for Swagger

    原文:Actions require unique method/path combination for Swagger services.AddSwaggerGen (c => { c.Re ...

  8. C#关键字:static

    一.static关键字 下面我设计了一个房贷利率上浮类(用来计算房贷利率上浮多少): public class InterestRateGoUp { public InterestRateGoUp() ...

  9. 利用windows服务实现整点报时功能

    程序语言:C# 实现目标:程序托管自动运行,每到整点播放语音报时. 准备素材:00——23点的整点报时声音文件. 实现过程: 1.新建windows服务项目 2.添加安装程序 3.设置服务属性 [添加 ...

  10. Linux系统:保证数据安全落盘

    在很多IO场景中,我们经常需要确保数据已经安全的写到磁盘上,以便在系统宕机重启之后还能读到这些数据.但是我们都知道,linux系统的IO路径还是很复杂的,分为很多层,每一层都可能会有buffer来加速 ...