(1)路由;(2)视图类(提供给用户访问相当于原来的视图函数);(3)序列化类(提供给视图类使用,把对象序列化成Json)
from rest_framework import serializers
注意:使用rest_framework,需先 settings.py的INSTALLED_APPS中先添加rest_framework。
# Application definition
INSTALLED_APPS = (
.........
"rest_framework",
........
)
4.一个Model类至少对应一个序列化类,继承于serializers.ModelSerializer。
序列化类的功能是把对应类型的对象转换成Json。
from rest_framework import viewsets
对于视图集ViewSet,我们除了可以自己手动指明请求方式与动作action之间的对应关系外,还可以使用路由Routers来帮助我们快速实现路由信息绑定、调用
REST framework提供了两个router类
创建router对象
from rest_framework import routers
router = routers.DefaultRouter()
7.1 安装
pip install coreapi
7.2 添加路由
from rest_framework.documentation import include_docs_urls
urlpatterns = [
...
path('docs/', include_docs_urls(title='站点页面标题'))
]
成功安装Django后,虚拟机终端会有 django-admin命令。
执行 django-admin startproject 项目名 即可创建出对应项目文件夹。
这个以项目命名的文件内包含一个 manage.py文件 和一个与项目名同名的文件夹。
import os
获取当前程序的文件名
os.path.abspath(__file__)
文件夹的名字
os.path.dirname(os.path.abspath(__file__))
所在文件夹的父目录
os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
以上代码一般用户获取项目的绝对路径
定义:统一资源定位符 Uniform Resource Locator。
作用:用来表示互联网上某个资源的地址。
URL的一般语法格式:
protocol://hostname[:port]/path[?query][#fragment]
注:[]代表其中的内容可省略。例如默认的端口80,就可以省略不写。
(1)protocol:
* http 通过HTTP访问该资源。格式为 http://
* https 通过安全的https访问该资源。格式为https://
* file 资源是本地计算机上的文件。格式为 file://
(2) hostname
是指存放资源的服务器的域名系统(DNS)主机名、域名或者IP地址。
(3)port
整数,可选,省略时使用默认端口。
各种协议的默认端口不同,如http的默认端口号为80.
(4)path 路由地址
有零或者多个“/” 符号隔开的字符串,一般用来表示主机上的一个目录或文件地址。
路由地址决定了服务器端会如何处理这个请求。
(5)query(查询)
可选,用于给静态网页传递参数,可有多个参数,用“&”符号隔开,每个参数的名和值用“=”符号隔开。
(6)fragment(信息片段)
字符串,用于指定网络资源中的片段。例如一个网页中有多个名词解释,可使用fragment直接定位到某一名词解释。使用#来表示。
step 1 :Django 从配置文件中,根据ROOT_URLCONF找到 主路由文件;默认情况下,该文件在项目同名目录下的urls文件中。
step 2:Django 加载主路由文件中的urlpatterns变量【包含很多路由的数组】。
step 3:依次匹配urlpatterns中的path,匹配到第一个合适的中断后续匹配。
step 4;匹配成功,调用对应的视图函数处理请求,返回相应;
匹配失败,返回404响应。
视图函数是用于接收一个浏览器请求(HttpRequest对象)并通过HttpResponse对象返回响应的函数。此函数可以接受浏览器请求并根据业务逻辑返回相应的响应内容给浏览器。
语法为
def XXX_view(request[,其它参数...])
return HttpResponse对象
导入
from django.urls inport path
语法
path(route,views,name=None)
参数
route:字符串类型,匹配的请求路径;
views:指定路径所对应的视图处理函数的名称;
name:为地址起别名,在模板中地址反向解析时使用。
语法:<转换器类型:自定义名>
作用:若转换器类型匹配到对应类型的数据,则将数据按照关键字传参的方式传递给视图函数。
例如:path('page/\<int:page>',views.xxx)
| 转化器类型 | 作用 | 样例 |
| str | 匹配除了’/‘之外的非空字符串 | “v1/users/<str:username>”匹配/v1/users/guoxiaohua |
| int | 匹配0或者任何正整数。返回一个int | "page/<int:page>"匹配/page/100 |
| slug | 匹配任意由ASCII字母或数字以及连字符和下划线组成的短标签 | "detail/<slug:sl>"匹配/detail/this-is-django |
| path | 匹配非空字段,包括路径分隔符’/‘ | "v1/users/<path:ph>"匹配/v1/users/a/b/c |
在url的匹配过程中可以使用正则表达式进行精确匹配。
语法:re_path(reg,view,name=xxxx)
正则表达式为命名分组模式(?p<name>pattern);匹配提取参数后用关键字传参方式传递给视图函数。
https://www.bilibili.com/video/BV1Q14y1t71j?p=2&spm_id_from=pageDriver
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o
我想解析一个已经存在的.mid文件,改变它的乐器,例如从“acousticgrandpiano”到“violin”,然后将它保存回去或作为另一个.mid文件。根据我在文档中看到的内容,该乐器通过program_change或patch_change指令进行了更改,但我找不到任何在已经存在的MIDI文件中执行此操作的库.他们似乎都只支持从头开始创建的MIDI文件。 最佳答案 MIDIpackage会为您完成此操作,但具体方法取决于midi文件的原始内容。一个MIDI文件由一个或多个音轨组成,每个音轨是十六个channel中任何一个上的
本文主要介绍在使用Selenium进行自动化测试或者任务时,对于使用了iframe的页面,如何定位iframe中的元素文章目录场景描述解决方案具体代码场景描述当我们在使用Selenium进行自动化测试的时候,可能会遇到一些界面或者窗体是使用HTML的iframe标签进行承载的。对于iframe中的标签,如果直接查找是无法找到的,会抛出没有找到元素的异常。比如近在咫尺的例子就是,CSDN的登录窗体就是使用的iframe,大家可以尝试通过F12开发者模式查看到的tag_name,class_name,id或者xpath来定位中的页面元素,会抛出NoSuchElementException异常。解决
目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称
最近在学习CAN,记录一下,也供大家参考交流。推荐几个我觉得很好的CAN学习,本文也是在看了他们的好文之后做的笔记首先是瑞萨的CAN入门,真的通透;秀!靠这篇我竟然2天理解了CAN协议!实战STM32F4CAN!原文链接:https://blog.csdn.net/XiaoXiaoPengBo/article/details/116206252CAN详解(小白教程)原文链接:https://blog.csdn.net/xwwwj/article/details/105372234一篇易懂的CAN通讯协议指南1一篇易懂的CAN通讯协议指南1-知乎(zhihu.com)视频推荐CAN总线个人知识总
深度学习部署:Windows安装pycocotools报错解决方法1.pycocotools库的简介2.pycocotools安装的坑3.解决办法更多Ai资讯:公主号AiCharm本系列是作者在跑一些深度学习实例时,遇到的各种各样的问题及解决办法,希望能够帮助到大家。ERROR:Commanderroredoutwithexitstatus1:'D:\Anaconda3\python.exe'-u-c'importsys,setuptools,tokenize;sys.argv[0]='"'"'C:\\Users\\46653\\AppData\\Local\\Temp\\pip-instal
2022/8/4更新支持加入水印水印必须包含透明图像,并且水印图像大小要等于原图像的大小pythonconvert_image_to_video.py-f30-mwatermark.pngim_dirout.mkv2022/6/21更新让命令行参数更加易用新的命令行使用方法pythonconvert_image_to_video.py-f30im_dirout.mkvFFMPEG命令行转换一组JPG图像到视频时,是将这组图像视为MJPG流。我需要转换一组PNG图像到视频,FFMPEG就不认了。pyav内置了ffmpeg库,不需要系统带有ffmpeg工具因此我使用ffmpeg的python包装p