iTunesify is a cross-platform Python script that utilizes the iTunes API to retrieve music release information, enabling you to organize and tag your music library effectively. Regardless of the type of music releaseβbe it albums, singles, EPs, or othersβiTunesify ensures your music library stays organized by generating a directory structure that groups your music files by artist and release type. It supports both FLAC and MP3 files. The script automatically loops through each directory in the specified music directory, processing and organizing each album one by one, and continues until the last album has been organized. The user has control over each iTunes collection being organized and can choose a different collection from the iTunes API by making a custom search, as well as skip the collection and proceed to the next one. Compatible with Windows, macOS, and Linux, iTunesify offers a user-friendly way to manage your music collection effectively.
- π Features
- π¨ Cover Art
- π οΈ Setup and Installation
- π Usage
- π© Command Line Flags (Args)
- βοΈ Configuration
- π§ Troubleshooting
- π€ Contributing
- π License
- π Acknowledgments
- Automatically loop through each album directory within your specified music directory, processing and organizing each album one by one until the last album has been organized.
- User control over the organization process: Choose a different collection from the iTunes API by making a custom search or skip the current collection and proceed to the next one.
- Search, fetch, and tag your music files with metadata from the iTunes API, supporting both FLAC and MP3 formats.
- Create subdirectories for each release type found on the iTunes API (e.g., "Albums" and "Singles & EPs").
- Clean up inconsistencies and unnecessary metadata from FLAC files using metaflac.
- Re-encode FLAC files with compression level 5 for optimal balance between file size and compression.
- Add an Audio MD5 checksum to ensure file integrity.
- Save the highest resolution uncompressed cover art when possible, and use the standard resolution as a fallback when not available.
iTunesify fetches the cover art for each release using the iTunes API. By default, it attempts to retrieve the uncompressed high-resolution cover art. If the uncompressed high-resolution cover art is not available, it falls back to the standard resolution.
The cover art is stored in the same directory as the music files, with the filename following this format: "cover.{extension}". If a cover art file with the same name already exists in the directory, it will be replaced by the new cover art.
Note: When processing both FLAC and MP3 files, embedded cover art will be removed during the metadata cleanup process. The new cover art fetched from the iTunes API will be saved separately in the same directory as the music files.
For a near hassle-free experience, use the precompiled executable from the release section. Note that you will still need to install flac
and metaflac
separately, as they are not bundled within the executable. Follow the instructions in the Install System Dependencies section to install flac
and metaflac
.
Once you have installed flac
and metaflac
, download the executable from the release section and run it.
If you prefer to work with the source code, follow these steps:
-
Clone the repository:
git clone https://github.com/yevhen2ii/itunesify
-
Navigate to the project folder:
cd itunesify
Create a virtual environment to prevent conflicts with other packages on your system:
-
Create a virtual environment:
python -m venv venv
-
Activate the virtual environment:
-
For Windows:
venv\Scripts\activate
-
For macOS/Linux:
source venv/bin/activate
-
With the virtual environment activated, use pip to install the required Python packages:
pip install -r requirements.txt
iTunesify depends on two external tools: flac and metaflac. Ensure that both flac
and metaflac
are installed on your system, available in your PATH
, or set their paths in the config.json
file. For more information on setting the paths in config.json
, refer to the Configuration section.
To install flac
and metaflac
, use the following command:
-
For macOS:
brew install flac
-
For Ubuntu:
sudo apt install flac
Note: When installing flac, metaflac will also be installed by default on macOS and Ubuntu. For more information and alternative downloads, visit the official FLAC website: https://xiph.org/flac/download.html
- Organize your music library into a directory structure where each artist has their own sub-directory, and within that sub-directory, each music collection has its own sub-directory. The audio files should be stored within these sub-directories. For example:
music/
artist1/
album1/
song1.flac
song2.flac
album2/
song1.flac
song2.flac
artist2/
album1/
song1.flac
song2.flac
album2/
song1.flac
song2.flac
- Download the iTunesify executable file or ensure you have the
itunesify.py
script from the cloned repository. - Open the command prompt or terminal and navigate to the directory containing the iTunesify executable file or the
itunesify.py
script. - Run the script by typing the following command:
For the executable:
itunesify -d [music_directory_path]
For the source code:
python itunesify.py -d [music_directory_path]
Replace [music_directory_path]
with the full path of the music directory that you have created in the format shown above, enclosed in quotes.
The script will automatically walk through your music library directory structure, extracting artist and collection information from the audio files to make a search query to the iTunes API. You will be prompted to confirm the organization for each collection found on iTunes, and after confirmation, the script will organize your music files accordingly.
You can use command line flags (arguments) to customize the behavior of iTunesify when running the script or executable. The following flags are supported:
-c, --config
: Specify a custom configuration file (JSON) path. By default, the script or executable will look for the configuration file (config.json
) in the same directory as the script or executable.-d, --directory
: Specify the music directory path. This is the path to the directory containing your music library, which will be organized by the script.
The configuration file config.json
contains the paths to various executables and files used by the script. Here is an example of what config.json
might look like on Windows:
{
"music_directory": "C:/Users/{username}/Downloads/music",
"censored_words_file": "censored_words.txt",
"flac_path": "flac",
"metaflac_path": "metaflac",
}
"metaflac_path"
: The path to themetaflac
executable. This is used to clean up inconsistencies and unnecessary metadata from FLAC files."flac_path"
: The path to theflac
executable. This is used to re-encode FLAC files with compression level 5 for optimal balance between file size and compression.
Note: If metaflac and flac are already in your system's PATH
, you can leave these values unchanged.
"censored_words_file"
: The path to thecensored_words.txt
file, which contains a list of censored words that should be replaced with their uncensored counterparts in album and track names. The format of the file iscensored_word:uncensored_word
. Note that this list is case-sensitive, so you need a new entry for each different case formatting of the word."music_directory"
: The path to the directory containing your music library. This is the directory that will be organized by the script.
If you encounter any issues while using iTunesify, consider the following troubleshooting steps:
- Double-check your music directory structure to ensure it matches the format expected by the script.
- Verify that you have installed all required Python dependencies and system dependencies if you are working from source.
- Ensure that your virtual environment is activated before running the script if you are working from source.
- Make sure that the
flac
andmetaflac
binaries are in your systemPATH
or placed in the root directory of the script. - Consult the script's output for any error messages or warnings that may provide more information about the issue.
If you continue to experience problems, don't hesitate to open an issue on the GitHub repository. Please include as much information as possible, such as your operating system, any error messages, and the steps you took before encountering the issue.
We welcome contributions to improve iTunesify and make it even more user-friendly. If you would like to contribute, please follow these steps:
- Fork the repository on GitHub.
- Clone your fork to your local machine.
- Create a new branch for your feature or bugfix, using a descriptive name.
- Make your changes and commit them to your branch.
- Push your branch to your fork on GitHub.
- Open a pull request from your branch to the original repository.
When submitting a pull request, please provide a clear description of your changes, including any issues they address, and any additional steps required to test or use your changes.
iTunesify is licensed under the MIT License. See the LICENSE file for more information.
Special thanks to the developers of the following libraries and tools that have been used in this project: