main.py 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. from fastapi import FastAPI, HTTPException
  2. from fastapi.middleware.cors import CORSMiddleware
  3. from pydantic import BaseModel
  4. import json
  5. from fastapi.responses import StreamingResponse
  6. from typing import AsyncGenerator, List, Dict, Any
  7. import uvicorn
  8. import traceback
  9. from xuanzhi_query import router as xz_router
  10. from sql_generator import SQLGenerator
  11. from config import DEFAULT_MODEL_TYPE
  12. import re
  13. app = FastAPI(title="Land Analysis API")
  14. app.include_router(xz_router)
  15. # 配置CORS
  16. app.add_middleware(
  17. CORSMiddleware,
  18. allow_origins=["*"],
  19. allow_credentials=True,
  20. allow_methods=["*"],
  21. allow_headers=["*"],
  22. )
  23. server_host = "0.0.0.0"
  24. server_port = 8521
  25. class QueryRequest(BaseModel):
  26. description: str
  27. class AnalysisResult(BaseModel):
  28. sql: str
  29. data: list
  30. visualization: dict = None
  31. similar_examples: List[Dict[str, Any]] = None
  32. @app.post("/land_analysis/stream")
  33. async def stream_land_analysis(request: QueryRequest):
  34. """
  35. 流式返回土地分析结果
  36. """
  37. sql_generator = SQLGenerator(model_type=DEFAULT_MODEL_TYPE)
  38. async def generate_stream() -> AsyncGenerator[str, None]:
  39. try:
  40. similar_examples = None
  41. # 流式生成SQL
  42. async for chunk in sql_generator.generate_sql_stream(request.description):
  43. data = json.loads(chunk)
  44. if data["type"] == "sql_generation":
  45. yield chunk
  46. elif data["type"] == "sql_result":
  47. sql = data["content"]
  48. result = await sql_generator.execute_sql(sql)
  49. if result["status"] == "error":
  50. yield json.dumps({
  51. "type": "error",
  52. "content": result["content"]
  53. }, ensure_ascii=False) + "\n"
  54. return
  55. yield json.dumps({
  56. "type": "result",
  57. "data": {
  58. "sql": sql,
  59. "exec_result": result["data"]
  60. }
  61. }, ensure_ascii=False) + "\n"
  62. else:
  63. yield chunk
  64. except Exception as e:
  65. traceback.print_exc()
  66. yield json.dumps({
  67. "type": "error",
  68. "content": str(e)
  69. }, ensure_ascii=False) + "\n"
  70. return StreamingResponse(
  71. generate_stream(),
  72. media_type="text/event-stream"
  73. )
  74. if __name__ == "__main__":
  75. uvicorn.run(app, host=server_host, port=server_port)
  76. # uvicorn.run("main:app", host=server_host, port=server_port, workers=5)