Initial commit: TradeMate 外贸小助手 MVP
项目结构: - backend/ Python FastAPI 后端 - uni-app/ uni-app跨端前端 - docs/ 设计文档 - docker-compose.yml Docker编排 - nginx/scripts/systemd 运维配置 已完成功能: - 用户认证 (JWT) - 智能翻译 + 回复建议 - 营销素材生成 - 客户管理 + 沉默检测 - 报价单管理 - 产品库管理 - 汇率换算 - 推送通知 (uni-push) - WhatsApp Webhook框架 - Celery定时任务
This commit is contained in:
@@ -0,0 +1,87 @@
|
||||
from typing import Dict, Any, Optional, List
|
||||
from sqlalchemy import select, text
|
||||
from datetime import datetime
|
||||
import logging
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class TradeCorpus:
|
||||
def __init__(self):
|
||||
self._ready = False
|
||||
|
||||
async def record(
|
||||
self,
|
||||
source_text: str,
|
||||
target_text: str,
|
||||
task_type: str,
|
||||
provider: str,
|
||||
source_lang: Optional[str] = None,
|
||||
target_lang: Optional[str] = None,
|
||||
quality_score: float = 0.5,
|
||||
user_edited: bool = False,
|
||||
metadata: Optional[Dict] = None,
|
||||
):
|
||||
try:
|
||||
from app.database import AsyncSessionLocal
|
||||
from app.models.corpus import CorpusEntry
|
||||
|
||||
async with AsyncSessionLocal() as session:
|
||||
entry = CorpusEntry(
|
||||
source_text=source_text[:2000],
|
||||
target_text=target_text[:2000],
|
||||
source_lang=source_lang,
|
||||
target_lang=target_lang,
|
||||
task_type=task_type,
|
||||
provider_used=provider,
|
||||
quality_score=quality_score,
|
||||
user_edited=user_edited,
|
||||
metadata=metadata or {},
|
||||
)
|
||||
session.add(entry)
|
||||
await session.commit()
|
||||
except Exception as e:
|
||||
logger.warning(f"Failed to record corpus entry: {e}")
|
||||
|
||||
async def find_similar(self, text: str, task_type: str, top_k: int = 3) -> List[Dict[str, Any]]:
|
||||
try:
|
||||
from app.database import AsyncSessionLocal
|
||||
from app.models.corpus import CorpusEntry
|
||||
|
||||
async with AsyncSessionLocal() as session:
|
||||
result = await session.execute(
|
||||
select(CorpusEntry)
|
||||
.where(CorpusEntry.task_type == task_type)
|
||||
.where(CorpusEntry.quality_score >= 0.6)
|
||||
.order_by(CorpusEntry.quality_score.desc())
|
||||
.limit(top_k)
|
||||
)
|
||||
entries = result.scalars().all()
|
||||
return [
|
||||
{
|
||||
"source": e.source_text,
|
||||
"target": e.target_text,
|
||||
"score": e.quality_score,
|
||||
}
|
||||
for e in entries
|
||||
]
|
||||
except Exception as e:
|
||||
logger.warning(f"Corpus search failed: {e}")
|
||||
return []
|
||||
|
||||
async def rate_entry(self, entry_id: str, rating: int):
|
||||
try:
|
||||
from app.database import AsyncSessionLocal
|
||||
from app.models.corpus import CorpusEntry
|
||||
|
||||
async with AsyncSessionLocal() as session:
|
||||
result = await session.execute(
|
||||
select(CorpusEntry).where(CorpusEntry.id == entry_id)
|
||||
)
|
||||
entry = result.scalar_one_or_none()
|
||||
if entry:
|
||||
entry.user_rating = rating
|
||||
entry.quality_score = rating / 5.0
|
||||
await session.commit()
|
||||
except Exception as e:
|
||||
logger.warning(f"Failed to rate corpus entry: {e}")
|
||||
Reference in New Issue
Block a user