Nodes Browser
ComfyDeploy: How ComfyUI-DataSet works in ComfyUI?
What is ComfyUI-DataSet?
Data research, preparation, and manipulation nodes for model trainers and artists.
How to install it in ComfyDeploy?
Head over to the machine page
- Click on the "Create a new machine" button
- Select the
Edit
build steps - Add a new step -> Custom Node
- Search for
ComfyUI-DataSet
and select it - Close the build step dialig and then click on the "Save" button to rebuild the machine
ComfyUI-DataSet
Data research, preparation, and manipulation nodes for model trainers and artists. </br>
Drag & drop image into your workspace for node layout
</br>Updates
[Nov 12th 2024]
- Now ClaudeAIChat, GroqAIChat and OpenAIChat works on API KEYS Defined in System Environment.
- Keys names are: OPENAI_API_KEY, GROQ_API_KEY, ANTHROPIC_API_KEY
Installation
Note: Please upgrade as this is a major update that renders all previous updates invalid.
Using comfy-cli
(https://github.com/yoland68/comfy-cli)
comfy node registry-install ComfyUI-DataSet
- https://registry.comfy.org/publishers/daxcay/nodes/comfyui-dataset
Manual Method
- Go to your Comfyui > Custom Nodes folder path > Run CMD
- Copy and Paste this command git clone
https://github.com/daxcay/ComfyUI-DataSet.git
- Then go inside ComfyUI-DataSet with cmd or open new.
- type
pip install -r requirements.txt
to install the dependencies
Automatic Method with Comfy Manager
-
Inside ComfyUI > Click Manager Button on Side.
-
Click
Custom Nodes Manager
and Search forDataSet
and Install this node: -
Restart ComfyUI and it should be good to go
Recommended Plugin
- ComfyUI-JDCN (https://github.com/daxcay/ComfyUI-JDCN)
You can find DataSet under this category:
</br>DataSet_Visualizer
The DataSet_Visualizer
node is designed to visualize dataset captions. It generates graphs offering various perspectives on token analysis. The word cloud represents token frequency with different sized fonts. The network graph illustrates the relationships between tokens. The frequency graph provides an exact metric of how often each token appears in your captions.
Inputs
- TextFileContents(STRING, required): the contents of the text file to be processed.
- Seperator(['comma', 'colon', 'space', 'pipe'], required): the delimiter used to separate tokens in the text file.
- WordCloudTop(INT, min: 1, max: 9999, required): the number of top tokens to be plotted in WordCloud.
- NetworkGraphTop(INT, min: 1, max: 9999, required): the number of top tokens having the highest interconnections within the captions.
- FrequencyGraphTop(INT, min: 1, max: 9999, required): the number of top tokens with highest frequency from highest to lowest.
Outputs
- GraphsPaths(STRING, list): the file paths of the generated visualizations. It includes paths for: WordCloud image, NetworkGraph image, FrequencyTable image
- GraphsImages(IMAGE, list): the generated images for the visualizations which can be used with PreviewImage and SaveImage node.
Example
</br>DataSet_CopyFiles
The DataSet_CopyFiles
node provides a method to copy files from a source folder to a destination folder using different modes: BlindCopy
and CopyByDestinationFiles
.
Inputs
- source_folder (STRING, default: "directory path", required): source folder path to the files.
- destination_folder (STRING, default: "directory path", required): destination folder path for the files copied.
- copy_mode (['BlindCopy', 'CopyByDestinationFiles'], required):
BlindCopy
: copies all files from source to the destination folder.CopyByDestinationFiles
: copies files from source folder to the destination only if there is a matching file (based on the base name) already present in the destination.
DataSet_TriggerWords
The DataSet_TriggerWords
node is designed to extract triggerwords from captions. The node identifies triggerwords as tokens containing BOTH letters and numbers.
Inputs
- TextFileContents (
STRING
, required): the contents of the text file(s) to be processed. - search(
['trigger_word_only', 'trigger_word_phrase']
, required):'trigger_word_only'
: extracts individual triggerwords only'trigger_word_phrase'
: extracts entire phrase (contained within two comma's) which contains a triggerword
Outputs
- Words (
STRING
, list): the extracted triggerwords or triggerword-containing phrase
DataSet_TextFilesLoadFromList
The DataSet_TextFilesLoad
node is designed to process the basic attributes of txt files. It can for instance extract filenames or filenames WITHOUT extensions, file-paths and file-contents. Useful for certain batched workflows. It takes a file directory path as input
Inputs
- TextFilePathsList(
STRING
, required): a list of file paths to the text files to be loaded. Only paths ending with.txt
will be processed.
Outputs
- TextFileNames(
STRING
, list): the names of the text files. - TextFileNamesWithoutExtension(
STRING
, list): the names of the text files without their extensions. - TextFilePaths(
STRING
, list): the file paths of the text files. - TextFileContents(
STRING
, list): the contents of the text files.
DataSet_TextFilesLoad
Same as above, but uses a widget path to file directory for input
Inputs
- directory(
STRING
, required): the directory path where the text files are located. The path should be specified as a string.
Outputs
- TextFileNames(
STRING
, list): the names of the text files in the directory. - TextFileNamesWithoutExtension(
STRING
, list): the names of the text files without their extensions. - TextFilePaths(
STRING
, list): the file paths of the text files in the directory. - TextFileContents(
STRING
, list): the contents of the text files in the directory.
DataSet_TextFilesSave
The DataSet_TextFilesSave
node is designed to save text file contents to a specified directory. Supports the following modes: overwriting, merging, creating new files, and merging before saving new files DONT UNDERSTAND THIS.
Inputs
- TextFileNames(
STRING
, required): the names of the text files to be saved. - TextFileContents(
STRING
, required): the contents of the text files to be saved. - destination(
STRING
, required): the directory path where the text files will be saved. - save_mode(['Overwrite', 'Merge', 'SaveNew', 'MergeAndSaveNew'], required): the mode of saving the files:
Overwrite
: overwrites existing files with the same name.Merge
: appends content to existing files with the same name.SaveNew
: saves new files with a unique name if a file with the same name already exists.MergeAndSaveNew
: merges content with existing files and then saves as a new file with a unique name if a file with the same name already exists.
DataSet_FindAndReplace
The DataSet_FindAndReplace
node finds and replaces a text pattern within caption text files.
Inputs
- TextFileContents(
STRING
, required): the text file contents to be processed - SearchFor(
STRING
, default: "search-text", required): the searched text pattern within theTextFileContents
. Supports multiline input. - ReplaceWith(
STRING
, default: "replacement-text", required): the replacement text for theSearchFor
pattern. Supports multiline input.
Outputs
- TextFileContents(
STRING
, list): the modified contents of the text files
DataSet_PathSelector
The DataSet_PathSelector
is useful for identifying images in a sub-dataset which are missing caption text files from a larger parent repository of image-text pairings. The node will search for orphaned text/image files in one directory which require the missing pair files with matching names from another directory.
Inputs
- search_in_directory(
STRING
, required): the sub-dataset directory missing pairings - search_for_extensions(
STRING
, required): the extensions of the orphaned files, separated by commas (e.g.,.txt, .csv
). - select_from_directory(
STRING
, required): the repository directory containing the complete text-image pairings. - select_extensions(
STRING
, required): the extensions of the required files to be added, separated by commas (e.g.,.txt, .csv
).
Outputs
- SelectedNamesWithExtension(
STRING
, list): the names of the required files with their extensions. - SelectedNamesWithoutExtension(
STRING
, list): the names of the required files without their extensions. - SelectedPaths(
STRING
, list): the full paths of the required files.
DataSet_ConceptManager
The DataSet_ConceptManager
node is designed to add/remove tokens within caption files, and it will allow you to place these tokens at designated positions within the caption
Inputs
- TextFileContents(
STRING
, required): the contents of the text file(s) to be processed. - Mode(
STRING
, required): the mode of operation:'add'
to add tokens or'remove'
to remove tokens. - Concepts(
STRING
, required): the concepts to add or remove, formatted as text + position (e.g.,"tag1 0, tag2 2"
for adding,"tag1, tag2"
for removing).
Outputs
- TextFileContents(
STRING
, list): the modified contents of the caption file(s)
DataSet_OpenAIChat
The DataSet_OpenAIChat
uses the OpenAI GPT chat to help you generate prompts.
Inputs
- model(STRING, required): select the OpenAI model. Options include
"GPTo"
,"gpt-3.5-turbo"
, etc. - api_url(STRING, default:
"https://api.openai.com/v1"
): the base URL for the API. - api_key(STRING, required): the API key for authentication.
- prompt(STRING, default: ""): the query chat. Prompt GPT to generate prompts
- token_length(INT, default: 1024): the maximum number of tokens (words).
Outputs
- STRING: the GPT generated new prompt
DataSet_LoadImage
The DataSet_LoadImage
node provides essential image file attributes for captioning with the DataSet_OpenAIChat
node. It leverages
Pillow and Numpy libraries.
Inputs
- image (STRING, required): the name of the image file to load from the input directory.
Outputs
- IMAGE: the image file.
- MASK: the mask associated with the image.
- STRING: the name of the image file.
- STRING: the name of the image file without extension.
- STRING: the full path of the image file.
- STRING: the directory path of the image file.
DataSet_SaveImage
The DataSet_SaveImage
node batch saves images to a specified directory with optional PNG metadata. Also uses Pillow and Numpy.
Inputs
- Images(IMAGE, required): list of images to save.
- ImageFilePrefix(STRING, default: "Image"): prefix for the saved image filenames.
- destination(STRING): directory path where images will be saved.
DataSet_OpenAIChatImage
The DataSet_OpenAIChat
uses the OpenAI GPTo multi-modal vision API in a chat framework, in order to caption images.
Inputs
- image(IMAGE, required): image to be processed.
- image_detail(STRING, default: "high": detail level of the image ("low" or "high").
- prompt(STRING, default: ""): text prompt for the AI model.
- model(STRING, default: "gpt-4o"): select the OpenAI model. Options include
"GPTo"
,"gpt-3.5-turbo"
, etc. - api_url(STRING, default: "https://api.openai.com/v1"): OpenAI API endpoint URL.
- api_key(STRING): the API key for authentication.
- token_length(INT, default: 1024): maximum token length for the generated response.
Outputs
- STRING: generated captions
DataSet_OpenAIChatImageBatch
The DataSet_OpenAIChatImageBatch
class extends the functionality of DataSet_OpenAIChatImage
to process batches of images with OpenAI's chat API for generating text catpions.
Inputs
- images(IMAGE, required): list of images to be processed.
- image_detail(STRING, default: "high"): detail level of the images ("low" or "high").
- prompt(STRING, default: ""): text prompt for the AI model.
- model(STRING, default: "gpt-4o"): select the OpenAI model. Options include
"GPTo"
,"gpt-3.5-turbo"
, etc. - api_url(STRING, default: "https://api.openai.com/v1"): OpenAI API endpoint URL.
- api_key(STRING): the API key for authentication.
- token_length(INT, default: 1024): maximum token length for the generated response.
Outputs
- STRING: list of generated captions
Credits
Raf Stahelin - Testing and Feedback
Daxton Caylor - ComfyUI Node Developer
-
Contact
- Twitter: @daxcay27
- Email - daxtoncaylor@gmail.com
- Discord - daxtoncaylor
- DiscordServer: https://discord.gg/UyGkJycvyW
-
Support
-
Buy me a coffee: https://buymeacoffee.com/daxtoncaylor
-
Support me on paypal: https://paypal.me/daxtoncaylor
-