|
- import time
- import openai
- import openai.error
- from common.token_bucket import TokenBucket
- from common.log import logger
- from config import conf
-
- # OPENAI提供的画图接口
- class OpenAIImage(object):
- def __init__(self):
- openai.api_key = conf().get('open_ai_api_key')
- if conf().get('rate_limit_dalle'):
- self.tb4dalle = TokenBucket(conf().get('rate_limit_dalle', 50))
-
- def create_img(self, query, retry_count=0):
- try:
- if conf().get('rate_limit_dalle') and not self.tb4dalle.get_token():
- return False, "请求太快了,请休息一下再问我吧"
- logger.info("[OPEN_AI] image_query={}".format(query))
- response = openai.Image.create(
- prompt=query, #图片描述
- n=1, #每次生成图片的数量
- size="256x256" #图片大小,可选有 256x256, 512x512, 1024x1024
- )
- image_url = response['data'][0]['url']
- logger.info("[OPEN_AI] image_url={}".format(image_url))
- return True, image_url
- except openai.error.RateLimitError as e:
- logger.warn(e)
- if retry_count < 1:
- time.sleep(5)
- logger.warn("[OPEN_AI] ImgCreate RateLimit exceed, 第{}次重试".format(retry_count+1))
- return self.create_img(query, retry_count+1)
- else:
- return False, "提问太快啦,请休息一下再问我吧"
- except Exception as e:
- logger.exception(e)
- return False, str(e)
|