(七)Flask之路由转换器

引子:

from flask import Flaskapp = Flask(__name__)# 通过使用<int>转换器,可以捕获URL中的整数值,并将其作为参数传递给视图函数。
@app.route('/index/<int:nid>', methods=['GET', 'POST'])
def index(nid):print(nid)return 'Index'if __name__ == '__main__':app.run('localhost', 4000)

上述代码中,<int:nid>部分表示nid是一个整数型的动态路由参数。当用户访问形如/index/666的路径时,会执行index函数并将匹配到的nid作为参数传递进去。

Flask自带的路由转换器

Flask提供了多种路由转换器(Route Converters),用于在路由规则中捕获和转换URL中的动态部分。这些转换器允许我们指定特定类型的参数,并限制其匹配的模式。

使用路由转换器时,只需像引子那样将转换器名称放在路由规则中的动态部分尖括号内即可。

常用路由转换器实际使用类似如下:

# 字符串
@app.route('/user/<username>')@app.route('/post/<int:post_id>')@app.route('/post/<float:post_id>')@app.route('/post/<path:path>')@app.route('/login', methods=['GET', 'POST'])

下面这段代码定义了Flask中默认的路由转换器(Route Converters)及其对应的类:

DEFAULT_CONVERTERS = {# 默认转换器,用于匹配任意不包含斜杠的字符串。它使用`UnicodeConverter`类进行转换。'default':            UnicodeConverter,# 同样是匹配任意不包含斜杠的字符串,使用`UnicodeConverter`类进行转换。'string':             UnicodeConverter,# 用于匹配任意类型的数据,可以包含斜杠等特殊字符。它使用`AnyConverter`类进行转换。'any':                AnyConverter,# 用于匹配包含斜杠的字符串,通常用于捕获整个路径段。它使用`PathConverter`类进行转换。'path':               PathConverter,# 用于匹配正整数,使用`IntegerConverter`类进行转换。'int':                IntegerConverter,# 用于匹配浮点数,使用`FloatConverter`类进行转换。'float':              FloatConverter,# 用于匹配符合UUID格式的字符串,使用`UUIDConverter`类进行转换。'uuid':               UUIDConverter,
}

这些默认的路由转换器提供了基本的类型匹配功能,可以根据URL中的动态部分的类型和模式进行精确匹配和转换。

在Flask中,我们也可以自定义自己的路由转换器,通过继承werkzeug.routing.BaseConverter类并实现相应的转换逻辑。然后,我们可以使用app.url_map.converters字典将自定义转换器注册到应用程序中。

自定义路由转换器:

自定义Flask的正则路由转换器,并将其应用于路由规则。

from flask import Flask
from werkzeug.routing import BaseConverterapp = Flask(__name__)class RegexConverter(BaseConverter):"""自定义URL匹配正则表达式"""def __init__(self, map, regex):super(RegexConverter, self).__init__(map)self.regex = regexdef to_python(self, value):"""路由匹配时,匹配成功后传递给视图函数中参数的值:param value::return:"""return int(value)def to_url(self, value):"""使用url_for反向生成url时,传递的参数经过该方法处理,返回的值用于生成url中的参数:param value::return:"""val = super(RegexConverter, self).to_url(value)return val# 添加到flask中
app.url_map.converters['regex'] = RegexConverter@app.route(r'/index/<regex("\d+"):nid>')
def index(nid):print(nid, type(nid))return 'Index'if __name__ == '__main__':app.run('localhost', 4000)

代码讲解:

  1. 引入必要的模块和库:

    • from flask import Flask:导入Flask类,用于创建Flask应用程序。
    • from werkzeug.routing import BaseConverter:导入BaseConverter类,它是Werkzeug库中的路由转换器基类,用于定义自定义转换器。
  2. 创建Flask应用程序实例:

    app = Flask(__name__)

  3. 定义自定义转换器类RegexConverter

    这个类继承自BaseConverter类,并重写了to_python方法和to_url方法,以便在路由匹配成功时和反向生成URL时对参数进行处理。

  4. 将自定义转换器添加到Flask应用程序中:

    app.url_map.converters['regex'] = RegexConverter

    通过将自定义转换器对象RegexConverter赋值给converters字典的键为'regex'的位置,将自定义转换器添加到Flask应用程序的URL映射器中。

  5. 定义视图函数:

    @app.route(r'/index/<regex("\d+"):nid>')
    def index(nid):print(nid, type(nid))return 'Index'
    

    在上述代码中,定义了一个名为index的视图函数,它接受一个参数nid,并使用自定义转换器<regex("\d+"):nid>来匹配URL中的动态部分。

一句话概括:

  • 上述代码使用自定义路由转换器RegexConverter来处理URL中的动态部分。通过定义自定义转换器,并将其添加到Flask应用程序中,可以实现根据正则表达式模式匹配URL并对参数进行处理。

在这里插入图片描述

看看在RegexConverter类的构造方法__init__中的两个参数:mapregex

  • map参数是一个Map对象,它代表URL映射器,用于将路由规则映射到相应的视图函数。通过调用父类BaseConverter的构造方法,将map作为参数传递给父类,以确保父类能够正常初始化。
  • regex参数是一个表示正则表达式的字符串,它用于定义匹配URL动态部分的正则表达式模式。

在上述这个例子中,我们自定义了一个名为RegexConverter的转换器,并将其应用于路由规则中的nid参数。使用<regex("\d+"):nid>作为路由规则,其中regex("\d+")表示我们想要匹配一个或多个数字。通过将regex("\d+")传递给自定义转换器的构造方法,在转换过程中会使用这个正则表达式模式来匹配URL中的动态部分。

**自定义转换器的作用是根据定义的正则表达式模式将URL中的动态部分转换为特定的数据类型,以便在视图函数中进行处理。**在这个例子中,我在自定义转换器的to_python方法中将匹配到的值转换为整数,以便在视图函数中使用。

如何应用于反向生成url_for()

在这里插入图片描述在这里插入图片描述在这里插入图片描述

简单讲几嘴to_url()函数:

to_url函数是自定义路由转换器中的一个方法,用于在使用url_for函数反向生成URL时对参数进行处理。

在这个例子中,我在自定义转换器RegexConverter中重写了to_url方法,以便在生成URL时对参数进行特定的处理。

to_url方法中,首先调用父类BaseConverterto_url方法来获取默认的URL参数字符串。然后,将获取到的默认值保存在变量val中,并返回它作为最终的URL参数字符串。

通过重写to_url方法,可以对参数进行任意的处理,并返回经过处理后的值,从而影响生成的URL结果。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【最新版配置conda环境】新版pycharm导入新版anaconda环境

最近下载了新版pycharm和新版anaconda&#xff0c;并且在命令行创建了环境&#xff0c;想着在pycharm里面导入环境。结果现在的导入方式发生了变化。 之前是通过导入Python.exe进行的。 现在&#xff1a; 当我们点击进去之后&#xff0c;会发现找不到python.exe了。 具体什么…

使用关键字abstract 声明抽象类-PHP8知识详解

抽象类只能作为父类使用&#xff0c;因为抽象类不能被实例化。抽象类使用关键字abstract 声明&#xff0c;具体的使用语法格式如下&#xff1a; abstract class 抽象类名称{ //抽象类的成员变量列表 abstract function 成员方法1(参数); //抽象类的成员方法 abstract functi…

VsCode好用的扩展插件

开发插件推荐: 别名路径跳转 >> 点击引用的变量名&#xff0c;ctrl 点击 跳转文件Auto Rename Tag >> 修改标签前缀&#xff0c;后缀标签会同时修改Chinees 中文(简体)Code Runner >> 纯js文件右键点击run code即可底部终端打印file-icons-mac >> ma…

【AI视野·今日NLP 自然语言处理论文速览 第四十三期】Thu, 28 Sep 2023

AI视野今日CS.NLP 自然语言处理论文速览 Thu, 28 Sep 2023 Totally 38 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Computation and Language Papers Cross-Modal Multi-Tasking for Speech-to-Text Translation via Hard Parameter Sharing Authors Brian Yan,…

在pycharm中弹出图后,需要关闭才会显示Process finished with exit code 0

在pycharm中弹出图后&#xff0c;需要关闭才会显示Process finished with exit code 0 在PyCharm中&#xff0c;当你运行一个Python程序并弹出一个图形窗口时&#xff0c;程序会等到图形窗口关闭后才会显示 “Process finished with exit code 0” 的消息。 这是 由于代码执行…

ASUS华硕飞行堡垒5笔记本FX504GM_FX80GM原装出厂Windows10系统

系统自带所有驱动、出厂主题壁纸、系统属性华硕专属LOGO标志、Office办公软件、MyASUS华硕电脑管家等预装程序 下载链接&#xff1a;https://pan.baidu.com/s/1C8vPvqiwqoUY3PxC915LXg?pwdv079

WebGL笔记:绘制多个点,三角形,以及画各种不同的线条,面

绘制多点 1 &#xff09; WebGL 缓冲区 我们在用js定点位的时候&#xff0c;肯定是要建立一份顶点数据的&#xff0c;这份顶点数据是给着色器的&#xff0c;因为着色器需要这份顶点数据绘图然而&#xff0c;我们在js中建立顶点数据&#xff0c;着色器肯定是拿不到的&#xff…

毛玻璃员工卡片悬停效果

效果展示 页面结构组成 通过效果展示图&#xff0c;我们可以看出页面布局比较常规&#xff0c;最核心的就是卡片&#xff0c;当鼠标没有悬停在卡片上时&#xff0c;文字和头像处于半透明状态&#xff0c;当鼠标悬停在卡片上是&#xff0c;底部会展示社交图标。 CSS 知识点 b…

【项目管理】--敏捷开发管理之Scrum

目录 一、前言二、what---敏捷开发是什么2.1、敏捷开发宣言2.2、敏捷开发原则2.3、一句话概述敏捷开发三、why---为什么会有敏捷开发3.1、传统开发模式和敏捷开发模式对比四、how---敏捷开发怎么实践到项目团队4.1、what---Scrum是什么4.2、what---Scrum有哪些内容(1)、Scrum之…

1、手把手教你学会使用 FlinkSQL客户端

目录 1、FlinkSQL客户端的功能 2、FlinkSQL客户端启动参数配置 2.1 基本语法 2.2 相关参数([MODE])&#xff1a; 2.3 相关参数(embedded [OPTIONS])&#xff1a; 3、启动Flink的sql-client 3.1 启动时使用初始化脚本 3.2 启动时指定依赖的jar包 3.3 基于yarn-session模…

libtorch之tensor的使用

1. tensor的创建 tensor的创建有三种常用的形式&#xff0c;如下所示 ones创建一个指定维度&#xff0c;数据全为1的tensor. 例子中的维度是2维&#xff0c;5行3列。 torch::Tensor t torch::ones({5,3}); zeros创建一个指定维度&#xff0c;数据全为0的tensor&#xff0c;例子…

Flutter笔记 - ListTile组件及其应用

Flutter笔记 ListTile组件及其应用 作者&#xff1a;李俊才 &#xff08;jcLee95&#xff09;&#xff1a;https://blog.csdn.net/qq_28550263 邮箱 &#xff1a;291148484163.com 本文地址&#xff1a;https://blog.csdn.net/qq_28550263/article/details/133411883 目 录 1. …

Ubuntu镜像源cn.arichinve.ubuntu.com不可用原因分析和解决

文章目录 Ubuntu查看系统版本Ubuntu更新系统不能更新Ubuntu查看APT更新源配置cn.archive.ubuntu.com已经自动跳转到清华镜像站Ubuntu变更镜像源地址备份原文件批量在VIM中变更 Ubuntu国内镜像站推荐推荐阅读 今天想要在Ubuntu环境下搭建一个测试环境&#xff0c;进入Ubuntu系统…

UE5 虚幻引擎 详解蓝图通信 必备的知识技能之一!!!

目录 0 引言1 直接蓝图通信1.1 在关卡蓝图中直接拖拽Actor1.2 Get Actor of Class/Get All Actors of Class 2 事件分发器2.1 创建事件分发器2.2 绑定事件分发器2.3 调用事件分发器 3 蓝图接口3.1 使用步骤3.2 为什么要使用蓝图接口 4 蓝图转换 0 引言 问题&#xff1a;为什么需…

加拿大人工智能数据搜索平台【Secoda】完成1400万美元A轮融资

来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 猛兽财经获悉&#xff0c;总部位于加拿大多伦多的人工智能数据搜索平台【Secoda】今日宣布已完成1400万美元A轮融资。 本轮融资由Craft Ventures领投&#xff0c;参与投资的投资机构有Abstract Ventures、现有投资者YCombi…

std::initializer_list详解

std::initializer_list介绍 initializer_list是C11提供的一种新类型&#xff0c;其定义于头文件<initializer_list>中&#xff0c;此头文件是工具库的一部分&#xff0c; <initializer_list>定义如下&#xff1a; namespace std {template<class E> class…

链表经典面试题(五)

求链表的公共结点 1.题目2.详细的图示3.详细注释和代码实现 1.题目 2.详细的图示 3.详细注释和代码实现 public class Solution {public ListNode getIntersectionNode(ListNode headA, ListNode headB) {//定义两个表示长度的指针,让它们指向headA和headB//我们暂时无法知道哪…

Git/GitHub/Idea的搭配使用

目录 1. Git 下载安装1.1. 下载安装1.2. 配置 GitHub 秘钥 2. Idea 配置 Git3. Idea 配置 GitHub3.1. 获取 GitHub Token3.2. Idea 根据 Token 登录 GitHub3.3. Idea 提交代码到远程仓库3.3.1. 配置本地仓库3.3.2. GitHub 创建远程仓库1. 创建单层目录2. 创建多层目录3. 删除目…

Promise击鼓传花

Promise击鼓传花 Promise系列导航前言一、Promise.prototype.then()1.语法2.代码及说明&#xff08;1&#xff09;代码段&#xff1a;&#xff08;2&#xff09;代码段&#xff1a;&#xff08;3&#xff09;代码段&#xff1a;&#xff08;4&#xff09;代码段&#xff1a;&am…

摆脱推荐算法,实现万物皆可『RSS』

前言 相信各位对推荐算法已经很熟悉了&#xff0c;平台基于推荐算法不断推送我们感兴趣的信息&#xff0c;但是身处推荐算法中心&#xff0c;有时我们可能感觉视野越来越闭塞&#xff0c;原来节约我们时间的推荐系统&#xff0c;这时却成了困住我们的信息茧房 那么也许 RSS&a…