Fundamental_Analysis/backend/app/schemas/financial.py
xucheng edfd51b0a7 feat: 昨日快照API与前端卡片;注册orgs路由;多项优化
- backend(financial): 新增 /china/{ts_code}/snapshot API,返回昨日交易日的收盘价/市值/PE/PB/股息率等

- backend(schemas): 新增 TodaySnapshotResponse

- backend(main): 注册 orgs 路由 /api/v1/orgs

- backend(providers:finnhub): 归一化财报字段并计算 gross_margin/net_margin/ROA/ROE

- backend(providers:tushare): 股东户数报告期与财报期对齐

- backend(routers/financial): years 默认改为 10(最大 10)

- config: analysis-config.json 切换到 qwen-flash-2025-07-28

- frontend(report/[symbol]): 新增“昨日快照”卡片、限制展示期数为10、优化增长与阈值高亮、修正类名与标题处理

- frontend(reports/[id]): 统一 period 变量与计算,修正表格 key

- frontend(hooks): 新增 useChinaSnapshot 钩子与类型

- scripts: dev.sh 增加调试输出
2025-11-05 17:00:32 +08:00

85 lines
1.9 KiB
Python

"""
Pydantic schemas for financial APIs
"""
from typing import Dict, List, Optional
from pydantic import BaseModel
class PeriodDataPoint(BaseModel):
period: str
value: Optional[float]
class StepRecord(BaseModel):
name: str
start_ts: str # ISO8601
end_ts: Optional[str] = None
duration_ms: Optional[int] = None
status: str # running|done|error
error: Optional[str] = None
class FinancialMeta(BaseModel):
started_at: str # ISO8601
finished_at: Optional[str] = None
elapsed_ms: Optional[int] = None
api_calls_total: int = 0
api_calls_by_group: Dict[str, int] = {}
current_action: Optional[str] = None
steps: List[StepRecord] = []
class BatchFinancialDataResponse(BaseModel):
ts_code: str
name: Optional[str] = None
series: Dict[str, List[PeriodDataPoint]]
meta: Optional[FinancialMeta] = None
class FinancialConfigResponse(BaseModel):
api_groups: Dict[str, List[dict]]
class TokenUsage(BaseModel):
prompt_tokens: int = 0
completion_tokens: int = 0
total_tokens: int = 0
class CompanyProfileResponse(BaseModel):
ts_code: str
company_name: Optional[str] = None
content: str
model: str
tokens: TokenUsage
elapsed_ms: int
success: bool = True
error: Optional[str] = None
class AnalysisResponse(BaseModel):
ts_code: str
company_name: Optional[str] = None
analysis_type: str
content: str
model: str
tokens: TokenUsage
elapsed_ms: int
success: bool = True
error: Optional[str] = None
class AnalysisConfigResponse(BaseModel):
analysis_modules: Dict[str, Dict]
class TodaySnapshotResponse(BaseModel):
ts_code: str
trade_date: str
name: Optional[str] = None
close: Optional[float] = None
pe: Optional[float] = None
pb: Optional[float] = None
dv_ratio: Optional[float] = None
total_mv: Optional[float] = None