ComfyUI Extension: SD Prompt Reader

Authored by receyuki

Created

Updated

310 stars

The ultimate solution for managing image metadata and multi-tool compatibility. ComfyUI node version of the SD Prompt Reader.

README

<div align="center"> <img alt="icon" src="https://github.com/receyuki/stable-diffusion-prompt-reader/raw/master/sd_prompt_reader/resources/icon-cube.png" width=20% height=20%> <h1>SD Prompt Reader Node</h1> <a href="https://github.com/receyuki/comfyui-prompt-reader-node/blob/master/LICENSE"> <img alt="GitHub" src="https://img.shields.io/github/license/receyuki/comfyui-prompt-reader-node"></a> <img alt="GitHub tag (with filter)" src="https://img.shields.io/github/v/tag/receyuki/comfyui-prompt-reader-node?label=node"> <a href="https://github.com/receyuki/stable-diffusion-prompt-reader"> <img alt="GitHub tag (with filter)" src="https://img.shields.io/github/v/tag/receyuki/stable-diffusion-prompt-reader?label=core"></a> <a href="https://github.com/psf/black"> <img alt="Code style: black" src="https://img.shields.io/badge/code%20style-black-000000.svg"></a> <br>

This is a subproject of the <a href="https://github.com/receyuki/stable-diffusion-prompt-reader">SD Prompt Reader.</a> It helps you extract metadata from images in any format supported by the <a href="https://github.com/receyuki/stable-diffusion-prompt-reader">SD Prompt Reader</a> and saves the images with additional metadata to ensure compatibility with metadata detection on websites such as Civitai. <br>

<p> <a href="#supported-formats">Supported Formats</a> • <a href="#installation">Installation</a> • <a href="#usage">Usage</a> • <a href="./CHANGELOG.md">Change Log</a> • <a href="#credits">Credits</a> </p> <img src="./images/screenshot_v130.png"> </div>

Supported Formats

| | PNG | JPEG | WEBP | TXT* | |----------------------------------------------------------------------------------------|:---:|:----:|:----:|:----:| | A1111's webUI | ✅ | ✅ | ✅ | ✅ | | Easy Diffusion | ✅ | ✅ | ✅ | | | StableSwarmUI* | ✅ | ✅ | | | | StableSwarmUI (prior to 0.5.8-alpha)* | ✅ | ✅ | | | | Fooocus-MRE* | ✅ | ✅ | | | | NovelAI (stealth pnginfo) | ✅ | | ✅ | | | NovelAI (legacy) | ✅ | | | | | InvokeAI | ✅ | | | | | InvokeAI (prior to 2.3.5-post.2) | ✅ | | | | | InvokeAI (prior to 1.15) | ✅ | | | | | ComfyUI* | ✅ | | | | | Draw Things | ✅ | | | | | Naifu(4chan) | ✅ | | | |

See SD Prompt Reader for details

Installation

[!NOTE] While ZIP package is available, it is strongly recommended not to use it for installation.

Install and update via ComfyUI Manager (Recommended)

Search for SD Prompt Reader in the ComfyUI Manager and install it.

Install manually

Please make sure to install the submodules along with the main repository.

  1. cd to the custom_node folder
  2. Clone this repo
    git clone --recursive https://github.com/receyuki/comfyui-prompt-reader-node.git
    
  3. Install dependencies
    cd comfyui-prompt-reader-node
    pip install -r requirements.txt
    

Update

When updating, don't forget to include the submodules along with the main repository.

git pull --recurse-submodules

Usage

Prompt Reader Node

<div align="center"> <img src="./images/reader.png" width="25%" height="25%" alt="reader node"> </div>

[!IMPORTANT] Due to custom nodes and complex workflows potentially causing issues with SD Prompt Reader's ability to read image metadata correctly, it is recommended to embed the Prompt Saver Node within the workflow to ensure maximum compatibility.

<details> <summary><b>More Information</b></summary>

parameter_index

  • For images containing multiple sets of parameters, such as those processed through hires-fix or refiner, you will need to modify the parameter_index to select the parameters you need

SDXL

  • For images generated by SDXL and containing multiple sets of prompts, the text_g will be combined with text_l into a single prompt

Batch Read

  • For batch processing, please use the Batch Loader node. When using the Batch Loader node for bulk reading, the preview image will not update, and the text box will only display the metadata of the last image.
<div align="center"> <img src="./images/loader2reader.png" width="50%" height="50%" alt="connect batch loader to prompt reader"> </div>

Additional Parameters

  • To read parameters other than the existing output, please connect the settings to the Parameter Extractor node.
<div align="center"> <img src="./images/reader2extractor.png" width="50%" height="50%" alt="connect prompt reader to parameter extractor"> </div>

MODEL_NAME

  • MODEL_NAME is a special output that matches the model name in the metadata with the existing models on the server according to the following priority:
    1. Identical path, filename, and extension.
    2. Identical filename, and extension. e.g. sd_xl_base.safetensors will be matched with SDXL\sd_xl_base.safetensors, and vice versa.
    3. Identical filename. e.g. sd_xl_base will be matched with SDXL\sd_xl_base.safetensors, and vice versa.
    4. If a matching model cannot be found, the original name will be outputted.
</details>

Prompt Saver Node

<div align="center"> <img src="./images/saver.png" width="25%" height="25%" alt="saver node"> </div>
  • The Prompt Saver Node and the Parameter Generator Node are designed to be used together.
  • The Prompt Saver Node will write additional metadata in the A1111 format to the output images to be compatible with any tools that support the A1111 format, including SD Prompt Reader and Civitai.
  • Due to custom nodes and complex workflows potentially causing issues with SD Prompt Reader's ability to read image metadata correctly, it's recommended to embed this node within the workflow to ensure maximum compatibility.

[!TIP] Since it's not possible to directly extract metadata from KSampler, it's necessary to use the Parameter Generator Node to generate parameters and simultaneously output them to the Prompt Saver Node and KSampler Node.

<details> <summary><b>More Information</b></summary>

Image Format

  • Only PNG format supports embedding both metadata and workflow at the same time. Other formats can only embed metadata.

Duplicate Filename

  • When the filename already exists, an index will be added at the end of the filename, e.g. file.png, file_1.png, file_2.png.

Hashes & Auto-Detection on Civitai

  • When calculate_hash is enabled, the node will compute the hash values of checkpoint, VAE, Lora, and embedding/Textual Inversion, and write them into the metadata. After the server restarts, or a new checkpoint, VAE, Lora, or embedding/Textual Inversion is loaded, the first image generation may take a longer time for hash calculation. The hash value will be stored in temporary storage without the need for repeated calculation, until the server is restarted.
  • When resource_hash is enabled, the resource hashes will be written into the metadata to support auto-detection on Civitai. This function will only run when calculate_hash is enabled.
  • If you need to calculate the hash of Lora, please use the Lora Loader Node or the Lora Selector Node. The hash value of the embedding/Textual Inversion will be automatically detected from the prompt.

save_metadata_file

  • When the save_metadata_file is turned on, the metadata will be saved as a TXT file with the same name alongside the image.

date_format & time_format

filename & path

  • %counter cannot be used for path, it can only be used for filename. This %counter is slightly different from the %counter in the built-in Saver node, it will count all image files in the path.

  • Please refer to the following table for placeholders supported by the filename and path.

    | | | |------------|------------| | %seed | %date | | %steps | %time | | %cfg | %counter | | %model | %extension | | %sampler | %quality | | %scheduler | |

</details>

Parameter Generator Node

<div align="center"> <img src="./images/generator.png" width="25%" height="25%" alt="generator node"> </div>
  • Since it's not possible to directly extract metadata from KSampler, it's necessary to use the Parameter Generator Node to generate parameters and simultaneously output them to both the Prompt Saver Node and KSampler Node.

[!TIP] The Parameter Generator Node can also be used as a control panel for complex ComfyUI workflows, just like the AP workflow.

<details> <summary><b>More Information</b></summary>

Optimal Resolution

refiner_start

  • refiner_start refers to the proportion of steps completed when the refiner starts running, i.e., the proportion of base steps to total steps. This is used to calculate the start_at_step (REFINER_START_STEP) required by the refiner KSampler under the selected step ratio.
</details>

Batch Loader Node

<div align="center"> <img src="./images/loader.png" width="25%" height="25%" alt="loader node"> </div>
  • The Batch Loader Node is specifically designed for the Prompt Reader Node to batch-read image files in a directory and cannot be used with other custom nodes.
<details> <summary><b>More Information</b></summary>
  • For batch processing, please connect the IMAGE output of the Batch Loader Node to the image input of the Prompt Reader Node.
<div align="center"> <img src="./images/loader2reader.png" width="50%" height="50%" alt="connect prompt reader to parameter extractor"> </div>

path

  • The path supports relative paths such as ./input/ or absolute paths like C:/Users/receyuki/Pictures.
  • Both \ and / are acceptable.
  • You can also input a single file or a list of files into the path, in which case the image_load_limit and start_index will not function.
</details>

Parameter Extractor Node

<div align="center"> <img src="./images/extractor.png" width="25%" height="25%" alt="extractor node"> </div>
  • The Parameter Extractor Node is an extension of the Prompt Reader Node, designed to retrieve the values of all parameters in the settings (including those parameters that the Prompt Reader Node cannot output). e.g. Hires upscaler
<details> <summary><b>More Information</b></summary>
  • Connect the SETTINGS of the Prompt Reader Node to the settings of the Parameter Extractor Node. After the first run, the parameter list will be loaded.
<div align="center"> <img src="./images/reader2extractor.png" width="50%" height="50%" alt="connect prompt reader to parameter extractor"> </div> </details>

Prompt Merger Node & Type Converter Node

<div align="center"> <img src="./images/merger_converter.png" width="25%" height="25%" alt="merger and converter node"> </div>
  • Since the A1111 format cannot store text_g and text_l separately, SDXL users need to use the Prompt Merger Node to combine text_g and text_l into a single prompt.
  • Since model_name, sampler_name, and scheduler are special types that cannot be directly used by some other nodes, You can use the Type Converter Node to convert them into STRING type.

Lora Loader Node & Lora Selector Node

<div align="center"> <img src="./images/lora.png" width="50%" height="50%" alt="lora loader and selector node"> </div>
  • The Lora Loader Node and Lora Selector Node are used to write Lora data into metadata and support auto-detection on Civitai.
<details> <summary><b>More Information</b></summary>
  • Replace the original loader with the Lora Loader Node, or connect the LORA_NAME output of the Lora Selector Node to the lora_name input of other lora loaders (built-in or custom), and link the NEXT_LORA output to the lora_name input of the Prompt Saver Node. Both of these nodes have the same function, please choose according to your needs.

Multiple Loras

  • If you need to load multiple Loras, please connect the Lora Loader Node or Lora Selector Node head to tail through last_lora and NEXT_LORA, and connect the NEXT_LORA at the end of the Lora chain to the lora_name input of the Prompt Saver Node.
  1. Lora Loader chain
<div align="center"> <img src="./images/lora_loader_chain.png" width="100%" height="100%" alt="lora loader chain"> </div>
  1. Lora Selector chain
<div align="center"> <img src="./images/lora_selector_chain.png" width="100%" height="100%" alt="lora loader chain"> </div> </details>

Example Workflow

<details> <summary><b>Simple Example</b></summary> <div align="center"> <img src="./workflows/simple_example.png" width="100%" height="100%" alt="example workflow"> </div> </details> <details> <summary><b>Lora Example</b></summary> <div align="center"> <img src="./workflows/lora_example.png" width="100%" height="100%" alt="example workflow"> </div> </details> <details> <summary><b>Hires-fix Example</b></summary> <div align="center"> <img src="./workflows/hires_fix_example.png" width="100%" height="100%" alt="example workflow"> </div> </details> <details> <summary><b>SDXL Example</b></summary> <div align="center"> <img src="./workflows/sdxl_example.png" width="100%" height="100%" alt="example workflow"> </div> </details>

Credits