Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

37 lines
1.5KB

  1. import time
  2. import openai
  3. from common.token_bucket import TokenBucket
  4. from common.log import logger
  5. from config import conf
  6. # OPENAI提供的画图接口
  7. class OpenAIImage(object):
  8. def __init__(self):
  9. openai.api_key = conf().get('open_ai_api_key')
  10. if conf().get('rate_limit_dalle'):
  11. self.tb4dalle = TokenBucket(conf().get('rate_limit_dalle', 50))
  12. def create_img(self, query, retry_count=0):
  13. try:
  14. if conf().get('rate_limit_dalle') and not self.tb4dalle.get_token():
  15. return False, "请求太快了,请休息一下再问我吧"
  16. logger.info("[OPEN_AI] image_query={}".format(query))
  17. response = openai.Image.create(
  18. prompt=query, #图片描述
  19. n=1, #每次生成图片的数量
  20. size="256x256" #图片大小,可选有 256x256, 512x512, 1024x1024
  21. )
  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.error.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, str(e)