AI掘金头条新闻系统 (Toutiao News)-获取新闻分类

目录

[1. common/result.py](#1. common/result.py)

[2. crud/news.py](#2. crud/news.py)

[3. routes/new.py](#3. routes/new.py)


1. common/result.py

python 复制代码
from typing import Any
from fastapi.encoders import jsonable_encoder
from pydantic import BaseModel


# 统一接口返回结构
class Result(BaseModel):
    code: int = 200
    message: str = "success"
    data: Any = None

    @classmethod
    def success(cls, data: Any = None, message: str = "success"):
        # jsonable_encoder 会把 SQLAlchemy ORM 对象、datetime 等类型
        # 转换成 FastAPI 可以正常返回的 JSON 数据
        return cls(
            code=200,
            message=message,
            data=jsonable_encoder(data)
        )

    @classmethod
    def error(cls, message: str = "error", code: int = 500, data: Any = None):
        # 失败响应统一走这里,方便前端按 code/message/data 处理
        return cls(
            code=code,
            message=message,
            data=jsonable_encoder(data)
        )

2. crud/news.py

python 复制代码
from sqlalchemy.ext.asyncio import AsyncSession
from sqlalchemy.sql.expression import select
from models.news import Category


async def get_categories(db: AsyncSession, skip: int = 0, limit: int = 100):
    """
    获取新闻分类
    :param db: 数据库异步会话
    :param skip: 跳过的数据条数,用于分页查询
    :param limit: 每次查询的数据条数,用于分页查询
    :return: 新闻分类 ORM 对象列表
    """
    # 构建查询语句
    # offset(skip):跳过前 skip 条数据
    # limit(limit):最多查询 limit 条数据
    stmt = select(Category).offset(skip).limit(limit)

    # 执行异步 SQL 查询
    result = await db.execute(stmt)

    # scalars():取出 Category ORM 对象
    # all():把查询结果转换成列表返回
    return result.scalars().all()

3. routes/new.py

python 复制代码
from fastapi import APIRouter
from fastapi.params import Depends
from sqlalchemy.ext.asyncio import AsyncSession
from common.result import Result
from crud import news
from config.db_confing import get_db

# 创建新闻模块路由
# prefix:当前文件下所有接口都会自动加上 /api/news 前缀
# tags:接口文档 Swagger 中显示的分组名称
router = APIRouter(prefix="/api/news", tags=["news"])


@router.get("/categories", response_model=Result)
async def get_categories(db: AsyncSession = Depends(get_db), skip: int = 0, limit: int = 100):
    """
    获取新闻分类
    :param db: 数据库异步会话
    :param skip: 跳过的数据条数,用于分页查询
    :param limit: 每次查询的数据条数,用于分页查询
    :return: 统一格式的新闻分类列表响应
    """
    # skip:跳过多少条数据;limit:最多返回多少条数据,用于分页查询

    # 调用 crud 层查询新闻分类列表
    categories = await news.get_categories(db, skip, limit)

    # 使用统一返回对象,避免每个接口都手写 code/message/data
    return Result.success(categories)
相关推荐
小小测试开发8 小时前
安装 Python 3.10+
开发语言·人工智能·python
梦想不只是梦与想8 小时前
Python 中的装饰器
python·装饰器
我叫唧唧波9 小时前
Python+AI 全栈学习笔记
人工智能·python·学习
不会就选b9 小时前
MySQL之视图
数据库·mysql
copyer_xyf9 小时前
Python 异常处理
前端·后端·python
麻雀飞吧10 小时前
期货多合约策略目标持仓怎么更新才不乱
python·区块链
Cthy_hy10 小时前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
LSssT.10 小时前
【01】Python 机器学习
开发语言·python
为爱停留10 小时前
给智能体装上「刹车」:中断(Interrupts)与人工审批全解析
python
llz_11210 小时前
web-第三次课后作业
前端·后端·web