news 2026/4/15 6:21:39

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/13 13:10:29

Seal视频下载器如何通过Material You动态色彩实现个性化视觉革命

Seal视频下载器如何通过Material You动态色彩实现个性化视觉革命 【免费下载链接】Seal &#x1f9ad; Video/Audio Downloader for Android, based on yt-dlp, designed with Material You 项目地址: https://gitcode.com/gh_mirrors/se/Seal 在现代Android生态系统中&…

作者头像 李华
网站建设 2026/4/12 23:05:01

OBS多平台直播实战手册:精通高效推流配置

OBS多平台直播实战手册&#xff1a;精通高效推流配置 【免费下载链接】obs-multi-rtmp OBS複数サイト同時配信プラグイン 项目地址: https://gitcode.com/gh_mirrors/ob/obs-multi-rtmp obs-multi-rtmp作为OBS Studio的专业级多平台推流解决方案&#xff0c;彻底改变了创…

作者头像 李华
网站建设 2026/4/13 12:55:04

JUCE音频开发终极指南:从零到专业级插件工程师

JUCE音频开发终极指南&#xff1a;从零到专业级插件工程师 【免费下载链接】JUCE 项目地址: https://gitcode.com/gh_mirrors/juc/JUCE 想要快速掌握音频插件开发技能&#xff1f;JUCE框架正是你实现这一目标的完美工具。作为业界领先的跨平台音频应用开发框架&#xf…

作者头像 李华
网站建设 2026/4/9 18:14:38

Agent Zero多语言界面终极配置指南:零代码解锁全球团队协作

Agent Zero多语言界面终极配置指南&#xff1a;零代码解锁全球团队协作 【免费下载链接】agent-zero Agent Zero AI framework 项目地址: https://gitcode.com/GitHub_Trending/ag/agent-zero Agent Zero AI框架提供全面的多语言界面配置功能&#xff0c;让用户无需编写…

作者头像 李华