open_ai_image.py 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. import time
  2. import openai
  3. from openai import OpenAI
  4. from common.log import logger
  5. from common.token_bucket import TokenBucket
  6. from config import conf
  7. client = OpenAI(api_key=conf().get("open_ai_api_key"),
  8. base_url=conf().get("open_ai_api_base", "https://api.openai.com/v1"))
  9. # OPENAI提供的画图接口
  10. class OpenAIImage(object):
  11. def __init__(self):
  12. if conf().get("rate_limit_dalle"):
  13. self.tb4dalle = TokenBucket(conf().get("rate_limit_dalle", 50))
  14. def create_img(self, query, retry_count=0, api_key=None, api_base=None):
  15. try:
  16. if conf().get("rate_limit_dalle") and not self.tb4dalle.get_token():
  17. return False, "请求太快了,请休息一下再问我吧"
  18. logger.info("[OPEN_AI] image_query={}".format(query))
  19. response = client.images.generate(prompt=query, # 图片描述
  20. n=1, # 每次生成图片的数量
  21. model=conf().get("text_to_image") or "dall-e-2")
  22. image_url = response.data[0].url
  23. logger.info("[OPEN_AI] image_url={}".format(image_url))
  24. return True, image_url
  25. except openai.RateLimitError as e:
  26. logger.warn(e)
  27. if retry_count < 1:
  28. time.sleep(5)
  29. logger.warn("[OPEN_AI] ImgCreate RateLimit exceed, 第{}次重试".format(retry_count + 1))
  30. return self.create_img(query, retry_count + 1)
  31. else:
  32. return False, "画图出现问题,请休息一下再问我吧"
  33. except Exception as e:
  34. logger.exception(e)
  35. return False, "画图出现问题,请休息一下再问我吧"