A script for adding replaygain tags to music files
Python Shell
Fetching latest commit…
Cannot retrieve the latest commit at this time.

README.mkdn

rganalysis.py: Add Replay Gain tags to your whole music library

To use this script, simply run it on your Music library directory. The help text (rganalysis.py --help) contains (almost) all you need to know:


usage: rganalysis [-h] [-f] [-i] [-n] [-g (track|album|auto)] [-j 4] [-m] [-q]
                  [-v]
                  [music_dir [music_dir ...]]

Add replaygain tags to your music files.

positional arguments: music_dir Directories in which to search for music files.

optional arguments: -h, --help show this help message and exit -f, --force-reanalyze Reanalyze all files and recalculate replaygain values, even if the files already have valid replaygain tags. Normally, only files missing or inconsistent replaygain tags will be analyzed. -i, --include-hidden Do not skip hidden files and directories. -n, --dry-run Don't modify any files. Only analyze and report gain. -g (track|album|auto), --gain-type (track|album|auto) Can be "album", "track", or "auto". If "track", only track gain values will be calculated, and album gain values will be erased. if "album", both track and album gain values will be calculated. If "auto", then "album" mode will be used except in directories that contain a file called "TRACKGAIN" or ".TRACKGAIN". In these directories, "track" mode will be used. The default setting is "auto". -j 4, --jobs 4 Number of albums to analyze in parallel. The default is the number of cores detected on your system. -m, --low-memory Use less memory by processing directories one by one rather than pre-computing the complete list of files to be processed. This will disable progress bars, but will allow rganalysis to run on very larg music collections without running out of memory. -q, --quiet Do not print informational messages. -v, --verbose Print debug messages that are probably only useful if something is going wrong.

Installation

First, you need to install audiotools, which is not available on PyPI. You can download the tarball from here and install it with pip install. Then you can install this package from Github using pip:

pip install https://github.com/DarwinAwardWinner/rganalysis/archive/master.zip

Lastly, if you want progress bars in the output, you should also install tqdm.

Note that rganalysis only works with Python 3.

What is an album?

When doing "album" or "audiophile" Replay Gain tags, one needs to carefully define an album. For example, if you happen to have half an album in FLAC format and the other half in MP3, they might be at different volumes to begin with, so calculating Replay Gain tags on the whole album is a bad thing -- the MP3s will end up too loud and the FLACs too quiet, or vice versa.

Anyway, this script considers two tracks to belong to the same "track set" for the purposes of calculating audiophile gain if:

  • They are in the same directory on the filesystem
  • They are both the same music format (MP3, OGG, FLAC, etc.)
  • They have the same "album" tag (preferring the "albumsort" tag if present)
  • They have the same "albumartist" (preferring the "albumartistsort" tag if present, and falling back to "artistsort" then "artist" if there is no album artist tagged)
  • They have the same "discnumber" tag (or lack thereof)

This means if you have a multi-artist album, you'll need to set the "albumartist" tag to the same value (e.g. "Various Artists") on all songs in the album in order for all the songs to be grouped as a single album. You can still set a different "artist" tag on each song.

See also

Transfercoder, a tool for transferring your music to your portable mp3 player while simultaneously transcoding music formats that the player doesn't recognize.