-
guest说:
fastapi+sqlchemy+pydantic get参数验证
from typing import Optional from fastapi import FastAPI from pydantic import BaseModel from sqlalchemy.ext.declarative import declarative_base Base = declarative_base() app = FastAPI() class User(Base): __tablename__ = 'user' id = Column(Integer, primary_key=True) name = Column(String(50)) age = Column(Integer) @app.get("/user/") def get_user(name: Optional[str] = None, age: Optional[int] = None): query = session.query(User.name, User.age) if name: query = query.filter(User.name == name) if age: query = query.filter(User.age == age) return query.all()
这段代码中,使用
@app.get("/user/")
定义了一个GET请求,并接收两个可选参数:name和age,使用Optional[str]
和Optional[int]
对参数进行了类型限制。然后,在函数中,使用
query = session.query(User.name, User.age)
查询用户表,如果参数name或age有值,则使用filter
方法对查询结果进行过滤,最后,使用return query.all()
返回结果。 -
guest说:
FastAPI中APIRouter()各参数使用方法,并给出案例
APIRouter():
(1)prefix:string,可选参数,路由前缀,会添加到每个路由中,可用于分组路由。
案例:
router = APIRouter(prefix="/user")
(2)tags:list,可选参数,为路由添加标签,可用于过滤路由。
案例:
router = APIRouter(tags=["user", "info"])
(3)dependencies:list,可选参数,为路由添加依赖,可用于实现可复用的路由功能。
案例:
router = APIRouter(dependencies=[deps.HTTPException])
-
guest说:
FastAPI中APIRouter()各参数使用方法,并给出一个文章增删改查的接口案例
FastAPI中APIRouter()常用参数如下:
- name:路由的名称,用于URL反向解析
- prefix:路由的前缀,把所有子路由添加到指定前缀
- tags:路由组的标签,用于路由分组
- dependencies:路由的依赖项,用于定义路由之前要执行的函数
下面是一个文章增删改查的接口案例:
from fastapi import APIRouter router = APIRouter(prefix="/articles", tags=["文章"]) @router.post("/") def create_article(): """创建文章""" pass @router.get("/{article_id}") def read_article(article_id: str): """读取文章""" pass @router.put("/{article_id}") def update_article(article_id: str): """更新文章""" pass @router.delete("/{article_id}") def delete_article(article_id: str): """删除文章""" pass