ylei 最近的时间轴更新
ylei

ylei

V2EX 第 670469 号会员,加入于 2024-01-09 16:21:59 +08:00
今日活跃度排名 3099
ylei 最近回复了
15 天前
回复了 dylyft 创建的主题 Python 小白求教个循环导入的问题
我 get 到问题了是 models/teams.py 和 models/users.py 相互引用

我觉得可以从两个方面入手
1. 需求上 users.py 里的表是否可以不依赖 teams
2. 存在外键的表独立出来 users_teams.py?
15 天前
回复了 dylyft 创建的主题 Python 小白求教个循环导入的问题
.
├── db.py
├── main.py
├── models
│ ├── __init__.py
│ ├── __pycache__
│ │ ├── __init__.cpython-311.pyc
│ │ ├── teams.cpython-311.pyc
│ │ └── users.cpython-311.pyc
│ ├── teams.py
│ └── users.py
├── __pycache__
│ ├── db.cpython-311.pyc
│ └── main.cpython-311.pyc
├── pyproject.toml
├── README.md
├── router
│ ├── __init__.py
│ ├── __pycache__
│ │ ├── __init__.cpython-311.pyc
│ │ ├── teams.cpython-311.pyc
│ │ └── users.cpython-311.pyc
│ ├── teams.py
│ └── users.py
├── test.db
└── uv.lock




db.py


from fastapi import Depends
from sqlmodel import Session
from typing import Generator
from sqlmodel import SQLModel, create_engine

DATABASE_URL = "sqlite:///./test.db"
engine = create_engine(DATABASE_URL, echo=True)


def get_session() -> Generator[Session, None, None]:
with Session(engine) as session:
yield session


SessionDep = Depends(get_session)


def create_db_and_tables():
SQLModel.metadata.create_all(engine)


teams.py


from sqlmodel import select
from sqlmodel import Session


from db import SessionDep
from models.teams import (
Team,
TeamPublicWithUser,
)
from fastapi import APIRouter


router = APIRouter(prefix="/teams", tags=["团队管理"])


@router.get("/{id}", summary="获取团队详情", response_model=TeamPublicWithUser)
async def get_team_api(id: int, db: Session = SessionDep, ):
team = db.exec(select(Team).where(Team.id == id)).first()
return team
2024-09-25 11:07:49 +08:00
回复了 garywill 创建的主题 Python 压缩 Python 代码,但不要改变换行方式,有这样的工具吗?
代码 -》 AST -》 代码
关于   ·   帮助文档   ·   自助推广系统   ·   博客   ·   API   ·   FAQ   ·   Solana   ·   883 人在线   最高记录 6679   ·     Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 11ms · UTC 21:11 · PVG 05:11 · LAX 13:11 · JFK 16:11
♥ Do have faith in what you're doing.