[Python] FastAPI基础:Path路径参数用法解析与实例

liftword2个月前 (02-25)技术文章12
  • 查询 query 参数(上一篇)
  • 路径 path 参数(本篇)
  • 请求体 body 参数(下一篇)
  • 请求头 header 参数

本篇项目目录结构:


1. 路径参数

路径参数是 URL 地址的一部分,是必填的。路径参数可以是:

  • 常规路径参数
  • 子路径参数(参数是路径)
  • 枚举路径参数

FastAPI 框架同样提供了对路径参数进行条件校验的支持,通过如下图的 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
    }

运行效果如下:


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
    }

运行效果如下:

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
    }

运行效果如下:


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 的开发效率还是挺高的,在日常工具、DEMO等工作中发挥了不少的作用,个人觉得确实值得学习的。

相关文章

readlink -f :显示文件全路径_显示文件完整路径

在 CentOS(及其他 Linux 系统)中,readlink 是一个用于解析符号链接(Symbolic Links)路径的命令。它可以帮助你获取符号链接指向的实际文件或目录的绝对路径,尤其在处理多...

推荐个超实用的Python标准库pathlib,玩转路径操作

pathlib学习 Python 时,尤其是在进行文件操作和数据处理时,经常会处理路径问题。最常用和常见的是 os.path 模块,它将路径当做字符串进行处理,如果使用不当可能导致难以察觉的错误,而且...

20 天学 Python 文件操作:Day 18 文件路径与操作系统兼容性

在开发跨平台应用程序时,文件路径和操作系统的兼容性是必须要处理的问题。今天我们将学习如何使用 Python 处理文件路径并确保代码在不同操作系统下运行正常。1. 文件路径的基本概念不同操作系统的文件路...

DeepSeek Python脚本定时任务设置:三大主流方案全面解析

在Python脚本定时任务设置中,根据不同的操作系统和需求场景,可采用以下三种主流方案:一、Windows系统方案(任务计划程序)1. 创建任务路径通过【控制面板】→【管理工具】→【任务计划程序】→【...

python学习笔记:09文件_python文件rb

文件的概念和编码1、文件的概念文件是以硬盘为载体存储在计算机上面的信息的集合,文件名字后面通常使用'.'+三个字母作为文件扩展名,用来表示文件的类型;2、文件的分类(1)文件大体上分成两类:文本文件、...