fastapi 中如何使用逗号分割 list,而不是同名键值对?
fastapi 通常将 query 参数解析为列表,当同名参数多次出现时。然而,在某些情况下,你可能更喜欢使用逗号分隔,生成单个字符串值。
解决方案:
有两种方法可以做到这一点:
1. 使用字符串参数
将 query 参数声明为字符串类型并自行解析:
source: optional[str] = query(none, description="请用`,`分割多个参数,如`manual,vdna,text-match`")
在你的代码中,解析后的值将存储在 parsed_source 变量中:
parsed_source = source.split(",") if source else []
2. 创建自定义依赖项
编写自己的依赖项以解析和验证 comma 分隔列表:
from fastapi import depends, httpexception from fastapi.params import depends async def split_comma_separated_list(csv_string: str) -> list[str]: """助手函数,将逗号分隔的字符串转换为列表。""" parsed_list = csv_string.split(",") for item in parsed_list: if not item: raise httpexception(status_code=400, detail="无效的参数") return parsed_list async def get_comma_separated_list(request: request, csv_string: str = depends(split_comma_separated_list)) -> list[str]: """获取逗号分隔列表的依赖项。""" return csv_string
在你的路由函数中,使用 get_comma_separated_list 依赖项:
@router.get("/my-route") async def my_route(csv_list: list[str] = Depends(get_comma_separated_list)): # `csv_list` 是一个包含逗号分隔条目的字符串的列表 return csv_list
使用 Asyncio 进行异步编程
掌握数据争吵:开发人员的简单指南
如何用Python计算已知三边长的三角形面积?
Python调用JS函数时出现UnicodeEncodeError:如何解决编码问题?
在使用Python和Selenium进行网页爬虫时,多线程并发执行偶尔报错而单线程却没有问题,这种现象通常是由以下几个原因导致的:浏览器实例共享问题: Selenium在多线程环境下,如果多个线程试图同时操作同一个浏览器实例,可能会导致冲突。每个线程应该使用独立的浏览器实例,但如果没有正确管理,可能会出现浏览器实例被多个线程共享的情况,从而引发异常。解决方案:确保每个线程都有自己的浏览器实例。例如,可以在每个线程中创建和管理自己的浏览器实例。from selenium import webdriver i
Pydantic BaseModel默认值:列表共享的坑与解决方法