The script Supports different download types: Lora, Checkpoints, Embeddings, Training Data, Other, or All and related images from a given CivitAI username, organizing them into appropriate directories and maintaining details in a text file.
It's designed to download only the files that are not already present in the specified username's folder. If the user uploads new models, running the script again will download only the newly uploaded files.
Example of Details.txt
Model URL: https://civitai.com/models/ID
File Name: Name of the Model.ending
File URL: https://civitai.com/api/download/models/ID
Image ID: ID
Image URL: https://image.civitai.com/Random_characters/width=450/ID.jpeg
File Structure
The downloaded files will be organized in the following structure:
model_downloads/
├── username1/
│ ├── Lora/
│ │ ├── model1/
│ │ │ ├── file1.safetensors
│ │ │ ├── image1.jpeg
│ │ │ └── details.txt
│ │ └── model2/
│ │ ├── file3.safetensors
│ │ ├── image2.jpeg
│ │ └── details.txt
│ ├── Checkpoints/
│ ├── Embeddings/
│ ├── Training_Data/
│ └── Other/
└── username2/
├── Lora/
├── Checkpoints/
├── Embeddings/
├── Training_Data/
└── Other/
install Python3
pip install -r requirements.txt
python civitAI_Model_downloader.py one or multiple usernames space separated
You can also give the script this 5 extra Arguments
--retry_delay
- default=10,
- "Retry delay in seconds."
--max_tries
- default=3,
- "Maximum number of retries."
--max_threads
- default=5,
- "Maximum number of concurrent threads.Too many produces API Failure."
--download_type
- Lora
- Checkpoints
- Embeddings
- Training_Data
- Other
- Default = All
--token
default=None
- "It will only Download the Public availabe Models"
- "Provide a Token and it can also Download those Models behind the CivitAI Login."
- If you forgot to Provide a Token the Script asks for your token.
Helper script fetch_all_models.py
python fetch_all_models.py --username <USERNAME> --token <API_TOKEN>
Example of username.txt created with helper script fetch_all_models.py
Summary:
Total - Count: 61
Checkpoints - Count: 12
Embeddings - Count: 33
Lora - Count: 11
Training_Data - Count: 2
Other - Count: 3
Detailed Listing:
Checkpoints - Count: 12
Checkpoints - Item: NAME
...
Embeddings - Count: 33
Embeddings - Item: NAME - Embeddings
...
Lora - Count: 11
Lora - Item: NAME
...
Training_Data - Count: 2
Training_Data - Item: NAME_training_data.zip
...
Other - Count: 3
Other - Item: NAME - Type: Other
...
You can create your API Key here Account Settings. Scoll down until the end and you find this Box
-
Download option for Training_Data added:
- Automatically creates its own download folder.
- Saves downloaded ZIP packages, associated images and a
detail.txt
file.
-
Introduction of a helper script
fetch_all_models.py
:- Retrieves model information from the CivitAI API based on username and API token.
- Categorizes the results and summarizes them in a text file
{username}.txt
. - Improves the overview of the user content and enables the statistics function.
- Can also be used standalone with the following command:
python fetch_all_models.py --username <USERNAME> --token <API_TOKEN>
-
Detection and categorization of new types:
- Script now recognizes the types VAE and Locon and assigns them to the category "Other".
-
Improvement of the filter for problematic characters:
- Optimization of filter functions to better handle problematic characters.
-
Code optimizations:
- All global variables are now at the beginning of the script.
- No more functions inside other functions.
- Merge lines of code where appropriate for better readability and maintainability.
-
Correct allocation of ZIP packages:
- ZIP packages are now downloaded to the appropriate folders according to API specifications, e.g. Training_Data, Lora, Other.
- ZIP packages without a specific category are still downloaded under "Other".
- Statistics fixed:
- The statistics function is now based on the new helper script
fetch_all_models.py
, which improves accuracy and functionality.
- The statistics function is now based on the new helper script
Enhanced Character Filtering:
The script has been modified to extensively filter out forbidden and problematic characters to prevent issues during the folder creation process.
Error Handling Improvements:
In cases where the script encounters characters that prevent folder creation, it now logs the name and URL of the affected download.
This information is recorded in a pre-existing text file, which is automatically named after the user whose content is being downloaded. This update allows users to manually complete downloads if issues arise.
failed_downloads_username.txt
Changed from Skipping image to Truncate when path length exceeding the limit.
New long awaited Feature
Selective Download Options
Users can now choose to download specific content types:
Lora
Checkpoints
Embeddings
Other
Everything but Lora, Checkpoints, Embeddings (grouped under Other_Model_types for less frequently downloaded items)
All
is the Default Download Behavior: The default option to download all available content remains if no specific download parameters are set.
Command Line and Interactive Enhancements:
Command Line Arguments: Users can directly specify their download preference (Lora, Checkpoints, Embedding, Other or All) via command line alongside other startup parameters.
Interactive Mode: If no command line arguments are specified, the program will prompt users interactively to select the content they wish to download. Pressing the Enter key activates the default settings to download all content.
Folder Structure Update:
Organized Storage: The program’s folder structure has been reorganized to support new download options efficiently:
Main directory: model_downloads/
User-specific subdirectory: Username/
Content-specific subfolders for Lora, Checkpoints, Embeddings, and Other_Model_types each containing item-specific subfolders.
Bugfix
The script will no longer remove the file name if it is written in the same way as the folder name. This could happen from time to time due to the sanitization function of the script.
New function to avoid OSError: [Errno 36] File name too long:
Pagination is fixed
New Function Multiple Usernames