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/
相关推荐
第一程序员2 分钟前
2026年Python就业市场分析:非科班转码者的机会与挑战
python·github
Thanks_ks3 分钟前
【第 002 讲】Python 标准开发环境搭建:运行环境 | 环境变量 | IDE 部署 | 配置优化
ide·python·pycharm·开发工具·环境配置·环境变量·编程基础
雷帝木木3 分钟前
Python 中的配置文件管理:从基础到高级应用
人工智能·python·深度学习·机器学习
郝学胜-神的一滴3 分钟前
Python 鸭子类型:优雅的多态哲学,让代码更自由
linux·服务器·开发语言·python·网络协议
小龙报5 分钟前
【必装软件】python及pycharm的安装与环境配置
开发语言·人工智能·python·语言模型·自然语言处理·pycharm·语音识别
QQ_1880838005 分钟前
python+flask+vue在线宠物医疗预约平台的设计与实现_b5z03zls
vue.js·python·flask
星辰徐哥5 分钟前
Python 基础与环境配置
开发语言·python
雷帝木木9 分钟前
Python元编程高级技巧:深入理解代码生成与动态行为
人工智能·python·深度学习·机器学习
第一程序员9 分钟前
Python元编程:非科班转码者的入门指南
python·github
shughui9 分钟前
2026年最新版Python安装和PyCharm安装教程(图文详细 附安装包)
开发语言·windows·python·pycharm·编辑器