You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

70 lines
2.2 KiB

import os
from Util import ConfigUtil
from Util.SDUtil import *
def C19(prompt_data, img, source_code, target_code):
#
prompt_data["12"]["inputs"]["image"] = img[0]
prompt_data["27"]["inputs"]["image"] = img[1]
# 替换关键词
# for i in range(len(source_code)):
# s = source_code[i]
# t = target_code[i]
# prompt_data["331"]["inputs"]["text"] = prompt_data["331"]["inputs"]["text"].replace(s, t)
# 过滤器,哪些返回节点中获取到的图片是有用的
myfilter = []
# 遍历prompt_data中的所有节点
for key, value in prompt_data.items():
if 'inputs' in value:
if 'filename_prefix' in value['inputs']:
if value['inputs']['filename_prefix'] == 'ComfyUI':
myfilter.append(key)
return prompt_data, myfilter
def runComfyUI(json_file, model_id, task_type_code, input_image, source_code, target_code):
# 创建目标目录
output_path = "../Out/Images/" + task_type_code + "/" + str(model_id) + "/"
if not os.path.exists(output_path):
os.makedirs(output_path)
# 生成一个唯一的客户端ID
client_id = str(uuid.uuid4())
# 上传图片
img = []
for x in input_image:
with open(x, "rb") as f:
y = upload_file(server_address, f, "", True)
img.append(y)
with open(json_file, 'r', encoding="utf-8") as fi:
prompt_data = json.load(fi)
prompt_data, myfilter = C19(prompt_data, img, source_code, target_code)
# 生成
files = generate_clip(server_address, prompt_data, client_id, output_path, myfilter)
print(files)
if __name__ == '__main__':
# 需要替换的提示词
source_code = ['']
# 替换后的提示词
target_code = ['']
# 使用哪个文件
json_file = '../JSON/19.json'
input_image = ['./Image/huanghai.png', './Image/littlehb.png']
# 请求
runComfyUI(json_file=json_file,
model_id=19,
task_type_code='User',
input_image=input_image,
source_code=source_code,
target_code=target_code)