news 2026/4/16 13:45:58

Python Flask 开发 - Flask 路径参数类型(string、int、float、path、uuid)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python Flask 开发 - Flask 路径参数类型(string、int、float、path、uuid)

查看路径参数类型

forconverter_name,converter_classinapp.url_map.converters.items():print(f"{converter_name}:{converter_class}")
# 输出结果 default: <class 'werkzeug.routing.converters.UnicodeConverter'> string: <class 'werkzeug.routing.converters.UnicodeConverter'> any: <class 'werkzeug.routing.converters.AnyConverter'> path: <class 'werkzeug.routing.converters.PathConverter'> int: <class 'werkzeug.routing.converters.IntegerConverter'> float: <class 'werkzeug.routing.converters.FloatConverter'> uuid: <class 'werkzeug.routing.converters.UUIDConverter'>

一、string

@app.route('/user/<string:username>')defshow_string(username):returnf'type: string, value:{username}, python_type:{type(username).__name__}'
  1. 测试/user/john_doe
# 输出结果 type: string, value: john_doe, python_type: str
  1. 测试/user/123
# 输出结果 type: string, value: 123, python_type: str
  1. 测试/user/john%20doe
# 输出结果 type: string, value: john doe, python_type: str

二、int

@app.route('/article/<int:article_id>')defshow_int(article_id):returnf'type: int, value:{article_id}, python_type:{type(article_id).__name__}'
  1. 测试/article/42
# 输出结果 type: int, value: 42, python_type: int
  1. 测试/article/0
# 输出结果 type: int, value: 0, python_type: int
  1. 测试/article/-100
# 输出结果 Not Found
  1. 测试/article/3.14
# 输出结果 Not Found
  1. 测试/article/abc
# 输出结果 Not Found
  1. 测试/article/10abc
# 输出结果 Not Found

三、float

@app.route('/price/<float:price>')defshow_float(price):returnf'type: float, value:{price}, python_type:{type(price).__name__}'
  1. 测试/price/19.99
# 输出结果 type: float, value: 19.99, python_type: float
  1. 测试/price/-5.5
# 输出结果 Not Found
  1. 测试/price/100
# 输出结果 Not Found
  1. 测试/price/100.0
# 输出结果 type: float, value: 100.0, python_type: float
  1. 测试/price/.5
# 输出结果 Not Found
  1. 测试/price/3.1415926
# 输出结果 type: float, value: 3.1415926, python_type: float
  1. 测试/price/10,5
# 输出结果 Not Found
  1. 测试/price/10k
# 输出结果 Not Found
  1. 测试/price/abc
# 输出结果 Not Found

四、path

1、演示
@app.route('/path/<path:filepath>')defshow_path(filepath):returnf'type: path, value:{filepath}, python_type:{type(filepath).__name__}'
  1. 测试/path/docs
# 输出结果 type: path, value: docs, python_type: str
  1. 测试/path/docs/api
# 输出结果 type: path, value: docs/api, python_type: str
  1. 测试/path/docs/api/v1
# 输出结果 type: path, value: docs/api/v1, python_type: str
  1. 测试/path/static/css/style.css
# 输出结果 type: path, value: static/css/style.css, python_type: str
  1. 测试/path/a/b/../d
# 输出结果 type: path, value: a/b/../d, python_type: str
2、string 处理路径类型的问题
@app.route('/path/<string:filepath>')defshow_path(filepath):returnf'type: string, value:{filepath}, python_type:{type(filepath).__name__}'
  1. 测试/path/docs
# 输出结果 type: string, value: docs, python_type: str
  1. 测试/path/docs/api
# 输出结果 Not Found
  1. 测试/path/docs/api/v1
# 输出结果 Not Found
  1. 测试/path/static/css/style.css
# 输出结果 Not Found
  1. 测试/path/a/b/../d
# 输出结果 Not Found

五、uuid

@app.route('/resource/<uuid:resource_id>')defshow_uuid(resource_id):returnf'type: uuid, value:{resource_id}, python_type:{type(resource_id).__name__}'
  1. 测试/resource/123e4567-e89b-12d3-a456-426614174000
# 输出结果 type: uuid, value: 123e4567-e89b-12d3-a456-426614174000, python_type: UUID
  1. 测试/resource/550e8400-e29b-41d4-a716-446655440000
# 输出结果 type: uuid, value: 550e8400-e29b-41d4-a716-446655440000, python_type: UUID
  1. 测试/resource/not-a-uuid
# 输出结果 Not Found
  1. 测试/resource/123
# 输出结果 Not Found
  1. 测试/resource/123e4567-e89b-12d3-a456-42661417400(短了)
# 输出结果 Not Found
  1. 测试/resource/123e4567-e89b-12d3-a456-4266141740000(长了)
# 输出结果 Not Found
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 11:07:14

PRQL多语言集成:企业级数据查询的革命性解决方案

PRQL多语言集成&#xff1a;企业级数据查询的革命性解决方案 【免费下载链接】prql PRQL/prql: 是一个类似于 SQL 的查询语言实现的库。适合用于查询各种数据库和数据格式。特点是支持多种数据库类型&#xff0c;提供了类似于 SQL 的查询语言。 项目地址: https://gitcode.co…

作者头像 李华
网站建设 2026/4/16 12:39:51

Qwen3-Omni多模态AI模型终极部署指南:5分钟快速上手实战

想要在本地快速体验多模态AI的强大功能吗&#xff1f;Qwen3-Omni-30B-A3B-Instruct作为开源AI领域的明星产品&#xff0c;原生支持文本、图像、音视频输入&#xff0c;还能实时生成语音响应。本文将带你从零开始&#xff0c;5分钟完成环境配置&#xff0c;快速掌握这个智能对话…

作者头像 李华
网站建设 2026/4/16 11:06:12

Node.js ESC/POS打印实战手册:解锁硬件控制新境界

Node.js ESC/POS打印实战手册&#xff1a;解锁硬件控制新境界 【免费下载链接】node-escpos &#x1f5a8;️ ESC/POS Printer driver for Node.js 项目地址: https://gitcode.com/gh_mirrors/no/node-escpos 在数字化转型浪潮中&#xff0c;打印机作为连接数字世界与物…

作者头像 李华
网站建设 2026/4/16 18:18:35

国巨薄膜精密电阻RT0805系列的噪声水平及适合的应用

国巨&#xff08;YAGEO&#xff09;RT0805系列薄膜精密电阻&#xff0c;是目前市场上兼具高精度、高稳定性与小型化优势的0805封装电阻代表。其具体系列包括RT0805FRB07、RT0805FRD07、RT0805FRE07、RT0805FRE10、RT0805FRE13、RT0805FRF07、RT0805LRB07、RT0805LRC07、RT0805L…

作者头像 李华
网站建设 2026/4/16 12:46:40

XVim终极指南:如何在Xcode中实现Vim高效编辑体验

XVim终极指南&#xff1a;如何在Xcode中实现Vim高效编辑体验 【免费下载链接】XVim Xcode plugin for Vim keybindings 项目地址: https://gitcode.com/gh_mirrors/xv/XVim 想要在Xcode开发环境中体验Vim的高效编辑魅力吗&#xff1f;XVim插件正是你梦寐以求的解决方案。…

作者头像 李华