Python NFT Generator
-
Clone Repository
git clone https://github.com/galperins4/NFT_Generator
-
Install Pillow Dependency
pip3 install pillow
- Update config items in nft.py (under import statements)
Config Option | Default Setting | Description |
---|---|---|
project_name | project name | Name of Project |
base_uri | https://ipfs.io/ipfs/ | URI link for where NFT is hosted (e.g., IPFS) |
total_nft | 2 | How many NFT's you want to mint |
rand_seed | 345698135 | Random value for pseudo-random number generator |
NFTSTORAGE | N | Y/N Option - Enables upload of images and metadata jsons to nft.storage |
NFTSTORAGE_API_KEY | MyKey | nft.storage API Key |
PINATA | N | Y/N Option - Enables pinning of images and metadata jsons to pinata |
PINATA_JWT | MyJWT | pinata JWT Token |
- Update estimated rarity in the section under the config items (See example below). Adjust the folder names to match your project and assign rarity to each layers attrbutes. Rarity order should be based on alphabetical file order in layer folder. These values should sum to 1 for each layer.
rarity = {"1-background": [0.25, 0.65, 0.10], "2-object": [0.10, 0.90], "3-text": [0.20, 0.30, 0.50]}
- Load .png image files into the attributes folders. An few examples have been provided to test the script. The nomenclature of the folders is as follows: layer-attribute. So for example 1-background is the first layer used which contains background images.
Important: All image files should be the same size (e.g., 400 x 400 pixels)
- Run the script
python3 nft.py
The script will do the following:
- Display a confirmation screen [Y/N] that the attributes/rarity are correct per layer
- Generate Images
- Run a duplicate check (Note: this could occur with a low number of attributes/traits)
- Output NFT images in to the ./images folder
- Output Metadata for images in the ./metadata folder
- Output a mint stats.json file with the full collection statistics (e.g., how many of each attribute/trait was selected)
- Output a NFT_Storage_Information file with cid's for image and metadata (if nft.storage is used)
Note: If using nft.storage functionality - considering running the script disabled first to confirm images. Once everything looks ok, re-rerun the script with the option enabled to upload all images and associated metadata to nft.storage
Inspiration for this script was drawn from the public repositories of the creators of BitBirds and Weird Whales. Their main profiles are linked below:
- Added pinata functionality
- Added nft.storage functionality
- Added rarity feature
- Initial Release