Django 自定义路由转换器

步骤

  1. 创建自定义转换器类

    • 必须定义 regex 属性(用于匹配参数)。
    • 必须实现 to_pythonto_url 方法。
      • to_python: 将匹配的参数转换为视图函数可用的 Python 数据。
      • to_url: 将数据转换为 URL 格式(用于反向解析)。
  2. 注册转换器

    • 使用 register_converter 将自定义转换器注册到 Django 的路由系统。
  3. 在路由中使用转换器

转换器导包
python 复制代码
from django.urls import converters

定义 一个匹配非数字的

python 复制代码
# 导入StringConverter 转换器
from django.urls.converters import StringConverter



# 继承StringConverter 直接定义或者修改方法
class NonumConverter(StringConverter):
    regex = r"[^\d]+"  # 匹配一个或多个非数字字符

    def to_python(self, value):
        # URL 参数直接作为字符串返回
        return value

    def to_url(self, value):
        # 返回适合插入到 URL 中的字符串
        return value

全局注册

python 复制代码
from django.urls.converters import DEFAULT_CONVERTERS



# 注册转换器到全局转换器集合
DEFAULT_CONVERTERS['nonum'] = NonumConverter

局部注册

python 复制代码
from django.urls import register_converter

register_converter(NonumConverter, 'nonum')

示例

创建转换器

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

python 复制代码
# converters.py


class FourDigitYearConverter:
    regex = r'\d{4}'  # 匹配四位数字

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

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

urls.py 中注册自定义转换器:

python 复制代码
from django.urls import path, register_converter
from . import converters, views

# 注册转换器
register_converter(converters.FourDigitYearConverter, 'yyyy')

urlpatterns = [
    path('year/<yyyy:year>/', views.year_view, name='year'),
]

视图函数

python 复制代码
from django.http import HttpResponse

def year_view(request, year):
    return HttpResponse(f"The year is {year}.")

反向解析

python 复制代码
from django.urls import reverse

url = reverse('year', kwargs={'year': 2024})
print(url)  # 输出:/year/2024/
相关推荐
花酒锄作田7 小时前
Postgres - Listen/Notify构建轻量级发布订阅系统
python·postgresql
Thomas.Sir7 小时前
第二章:LlamaIndex 的基本概念
人工智能·python·ai·llama·llamaindex
m0_694845578 小时前
Dify部署教程:从AI原型到生产系统的一站式方案
服务器·人工智能·python·数据分析·开源
小码哥_常8 小时前
Spring Boot 中JWT登录授权+无感刷新,看这篇就够了!
后端
李昊哲小课9 小时前
Python办公自动化教程 - 第7章 综合实战案例 - 企业销售管理系统
开发语言·python·数据分析·excel·数据可视化·openpyxl
码农BookSea9 小时前
深度解析Skills:从Prompt到能力复用的技术革命
后端·ai编程
不知名的老吴9 小时前
返回None还是空集合?防御式编程的关键细节
开发语言·python
计算机毕设指导69 小时前
基于SpringBoot校园学生健康监测管理系统【源码文末联系】
java·spring boot·后端·spring·tomcat·maven·intellij-idea
希望永不加班10 小时前
SpringBoot 数据库连接池配置(HikariCP)最佳实践
java·数据库·spring boot·后端·spring
李昊哲小课10 小时前
Python办公自动化教程 - 第5章 图表创建 - 让数据可视化
python·信息可视化·数据分析·数据可视化·openpyxl