gemini.py 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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
  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. # 如果没有基础密钥,尝试使用第一个多密钥
  21. self.api_key = os.getenv('GEMINI_API_KEY_1')
  22. if not self.api_key:
  23. raise ValueError("未找到GEMINI_API_KEY或GEMINI_API_KEY_1环境变量")
  24. genai.configure(api_key=self.api_key)
  25. def process(self, content: Any, system_prompt: str) -> Dict[str, Any]:
  26. try:
  27. # 处理输入内容格式
  28. if isinstance(content, dict):
  29. # 将字典转换为JSON字符串
  30. formatted_content = json.dumps(content, ensure_ascii=False)
  31. else:
  32. formatted_content = content
  33. # 创建带有 system_instruction 的模型实例
  34. model_with_system = genai.GenerativeModel(
  35. 'gemini-2.5-flash',
  36. system_instruction=system_prompt
  37. )
  38. # 调用 Gemini API,设置超时时间
  39. response = model_with_system.generate_content(
  40. contents=formatted_content
  41. )
  42. # 尝试解析 JSON 响应
  43. return response.text
  44. except Exception as e:
  45. print(f"Gemini API 调用失败: {e}")
  46. return {"error": str(e), "content": content}
  47. def batch_process(self, contents: list, system_prompt: str) -> list:
  48. results = []
  49. for content in contents:
  50. result = self.process(content, system_prompt)
  51. results.append(result)
  52. return results