gemini.py 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. 简单的 Gemini 处理器
  5. 用于满足导入需求,实际功能可以根据需要扩展
  6. """
  7. import os
  8. import json
  9. from typing import Any, Dict, Optional
  10. from dotenv import load_dotenv
  11. import google.generativeai as genai
  12. class GeminiProcessor:
  13. """Gemini API 处理器"""
  14. def __init__(self):
  15. # 加载环境变量
  16. load_dotenv()
  17. # 获取API密钥
  18. self.api_key = os.getenv('GEMINI_API_KEY')
  19. if not self.api_key:
  20. raise ValueError("未找到GEMINI_API_KEY环境变量")
  21. # 配置Gemini
  22. genai.configure(api_key=self.api_key)
  23. def process(self, content: Any, system_prompt: str) -> Dict[str, Any]:
  24. try:
  25. # 处理输入内容格式
  26. if isinstance(content, dict):
  27. # 将字典转换为JSON字符串
  28. formatted_content = json.dumps(content, ensure_ascii=False)
  29. else:
  30. formatted_content = content
  31. # 创建带有 system_instruction 的模型实例
  32. model_with_system = genai.GenerativeModel(
  33. 'gemini-2.5-flash',
  34. system_instruction=system_prompt
  35. )
  36. # 调用 Gemini API
  37. response = model_with_system.generate_content(
  38. contents=formatted_content
  39. )
  40. # 尝试解析 JSON 响应
  41. return response.text
  42. except Exception as e:
  43. print(f"Gemini API 调用失败: {e}")
  44. return {"error": str(e), "content": content}
  45. def batch_process(self, contents: list, system_prompt: str) -> list:
  46. results = []
  47. for content in contents:
  48. result = self.process(content, system_prompt)
  49. results.append(result)
  50. return results