Spaces:
Sleeping
Sleeping
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) |