Flask 自定义路由转换器

步骤

  1. 创建自定义转换器类

    • 继承 werkzeug.routing.BaseConverter
    • 实现 to_python 和(可选)to_url 方法。
  2. 将转换器注册到 Flask 应用

  3. 在路由中使用转换器

示例

创建转换器

假设需要自定义一个转换器 FourDigitYearConverter,用于匹配四位年份。

python 复制代码
# converters.py



from werkzeug.routing import BaseConverter

class FourDigitYearConverter(BaseConverter):
    def __init__(self, url_map):
        super().__init__(url_map)
        self.regex = r'\d{4}'  # 匹配四位数字

    def to_python(self, value):
        return int(value)  # 转换为整数

    def to_url(self, value):
        return f"{value:04d}"  # 确保是四位数字
注册转换器

在 Flask 应用中注册转换器:

python 复制代码
from flask import Flask
from converters import FourDigitYearConverter

app = Flask(__name__)

# 注册转换器
app.url_map.converters['yyyy'] = FourDigitYearConverter

定义路由

python 复制代码
@app.route('/year/<yyyy:year>/')
def year_view(year):
    return f"The year is {year}."
测试路由

访问 /year/2024/ 时:

  • URL 参数 2024 被捕获并转换为整数 2024
反向生成 URL
python 复制代码
with app.test_request_context():
    url = flask.url_for('year_view', year=2024)
    print(url)  # 输出:/year/2024/
相关推荐
jieyucx几秒前
Go 语言零基础入门:编写第一个 Hello World 程序
开发语言·后端·golang
一点一一1 分钟前
nestjs+langchain:大模型的基本调用、对message的
人工智能·后端
生信研究猿4 分钟前
第2题-大模型Attention模块开发
python
2401_871696524 分钟前
JavaScript中代码覆盖率Coverage在精简脚本中的应用
jvm·数据库·python
NineData5 分钟前
NineData将亮相2026德国汉诺威工业博览会
运维·数据库·后端
XiYang-DING7 分钟前
【Java EE】多线程(1)
java·python·java-ee
m0_7349497911 分钟前
Python GUI界面如何实现主题美化_引入ttk模块实现原生外观风格
jvm·数据库·python
jieyucx12 分钟前
Go 语言基础语法:变量、常量与数据类型详解
开发语言·后端·golang
光影少年13 分钟前
Python+LangGraph学习路线及发展前景
开发语言·人工智能·python·学习