- 查询 query 参数(上一篇)
- 路径 path 参数(本篇)
- 请求体 body 参数(下一篇)
- 请求头 header 参数
本篇项目目录结构:
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/d5925f19c8b54a9bb59041cc9dfd4194.jpg)
Path 路径参数示例项目结构
1. 路径参数
路径参数是 URL 地址的一部分,是必填的。路径参数可以是:
- 常规路径参数
- 子路径参数(参数是路径)
- 枚举路径参数
FastAPI 框架同样提供了对路径参数进行条件校验的支持,通过如下图的 Path 实现。
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/f9ec2ff862ca4987979113e566f097bb.jpg)
path 类
下面一一介绍。
1.1. 常规路径参数
常规路径路由参数格式是使用花括号 {},列如:
/patient/{patient_id}
上面的 {patient_id} 会使用传递的路径中的具体值替换。详细的示例如下:
# 通过 @app.get 装饰器创建一个 API 端点路由
# 常规路径参数
@app.get("/usr/{usr_id}/article/{article_id}", summary='获取用户文章')
async def query_user_article(usr_id: int, article_id: str):
return {
"user_id": usr_id,
"article_id": article_id
}
运行效果如下:
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/191bb42a98d5466ab5e16f69fed95f95.jpg)
swagger ui
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/c1ca8891f8144516b1c684fec2ec0684.jpg)
常规path参数
1.2. 子路径参数
路径参数的值本身是路径的情况,需要指定其为 path,语法格式:{参数: path}。示例如下:
# {file_path:path},path 表明该参数是路径
@app.get("/usr/{file_path:path}", summary="获取文件")
async def get_file(file_path: str):
return {
"file_path": file_path
}
运行效果如下:
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/453e9615b71d4c8c88b385ed275c0952.jpg)
swagger ui
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/70d36f6f8bc44b5d8ca66e189c360c78.jpg)
路径示例1
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/f2495b7f1bf4408180ec4be99a4383ec.jpg)
路径示例2
1.3. 枚举路径参数
一般在参数的值是固定的几个值时,会用枚举,当传入的值不是这些值,FastAPI 会抛出异常。在使用枚举前,前花些时间了解一下 python 中的枚举类型吧,官方文档:
(1) https://docs.python.org/zh-cn/3/library/enum.html
(2) https://docs.python.org/zh-cn/3/howto/enum.html
下面先来定义自己的枚举,这里把 类 和 函数 两种方式都尝试了一下:
from enum import Enum
# 函数的方式
Weekday = Enum('Weekday', ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday'])
# 类的方式
class ColorModel(str, Enum):
RED = 'red'
GREEN = 'green'
BLUE = 'blue'
YELLOW = 'yellow'
PURPLE = 'purple'
使用枚举类型作为参数:
from mymodels import ColorModel, Weekday
# 如果传入的值不是这些值,则会抛异常
@app.get("/info/{color}", summary="获取颜色信息")
async def get_color(color: ColorModel):
if color == ColorModel.RED:
msg = f'weekday: {Weekday.Monday.name}, color: {color.name}'
elif color == ColorModel.GREEN:
msg = f'weekday: {Weekday.Tuesday.value}, color: {color.value}'
elif color == ColorModel.BLUE:
msg = f'weekday: {Weekday.Monday.name} = {Weekday.Monday.value}, color: {color.name} = {color.value}'
else:
msg = f'{color} ignored'
return {
"weekday_color": msg
}
运行效果如下:
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/dd66fe3238b14a61b65a979d48510f58.jpg)
swagger ui
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/9951017634104846b26a0616f5137329.jpg)
枚举类型
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/dce3e94f75344a51a45706893b6762f4.jpg)
抛异常
1.4. 路径参数条件校验
文章一开头已经提到 FastAPI 提供 Path 类的封装来设置 路径参数 的条件校验。下面是具体的示例代码:
from fastapi import FastAPI, Path
# FastAPI 提供对 Path 类的封装来设置 路径参数 的条件校验
# ... 表明必填
@app.get("/data/{data_id}/txt/{txt_id}", summary='获取数据')
async def query_data(data_id: int = Path(..., ge=100, title='数据ID', description='数据唯一编号'),
txt_id: str = Path(..., min_length=1, max_length=30)):
return {
"data_id": data_id,
"txt_id": txt_id
}
运行效果如下:
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/2c058e9bc8424b2aae0f49ab1bb629bf.jpg)
swagger ui
![[Python] FastAPI基础:Path路径参数用法解析与实例](https://pic.songma.com/blogimg/20250819/87c6e2cd0c634bacb1ef2fbe10d63c12.jpg)
校验效果
python 的开发效率还是挺高的,在日常工具、DEMO等工作中发挥了不少的作用,个人觉得的确 值得学习的。
© 版权声明
文章版权归作者所有,未经允许请勿转载。如内容涉嫌侵权,请在本页底部进入<联系我们>进行举报投诉!
THE END
















暂无评论内容