ID3 Frames¶
Below is the list of ID3 frames supported by puddletag descriptions of their usage in puddletag. These can be accessed available via the Extended Tags Dialog (Edit -> Extended Tags). puddletag writes only UTF-8 encoded ID3v2.4 and ID3v2.3 (with the option of including ID3v1) tags.
Text Frames¶
Text frames can store any text. Multiple values are allowed per field.
Comment frames are written to the COMM frame. Multiple values are allowed per comment field, but storing different comment frames requires a different description for each frame. This is denoted by any text following the comment: identifier. Eg. comment:numbertwo (no spaces allowed) will have description numbertwo. The first COMM frame encountered without a description will be used as the comment field. Likewise creating a comment field will write to a description-less COMM frame.
Any unknown field is assumed to be a user-defined field. Therefore writing to the field ‘mytag’ will write to the ID3 tag frame TXXX:mytag.
The list of ID3 text frames as supported by puddletag is shown below. Multiple values per field are allowed. The iTunes frames are only supported by Mutagen 1.17 and above.
| puddletag field | ID3v2.4 Frame | 
|---|---|
| album | TALB | 
| albumartist | TPE2 | 
| albumsortorder | TSOA | 
| arranger | TPE4 | 
| artist | TPE1 | 
| audiodelay | TDLY | 
| audiolength | TLEN | 
| audiosize | TSIZ | 
| author | TOLY | 
| bpm | TBPM | 
| composer | TCOM | 
| conductor | TPE3 | 
| copyright | TCOP | 
| date | TDAT | 
| discnumber | TPOS | 
| encodedby | TENC | 
| encodingsettings | TSSE | 
| filename | TOFN | 
| fileowner | TOWN | 
| filetype | TFLT | 
| genre | TCON | 
| grouping | TIT1 | 
| initialkey | TKEY | 
| isrc | TSRC | 
| itunesalbumsortorder | TSO2 | 
| itunescompilationflag | TCMP | 
| itunescomposersortorder | TSOC | 
| language | TLAN | 
| lyricist | TEXT | 
| mediatype | TMED | 
| mood | TMOO | 
| organization | TPUB | 
| originalalbum | TOAL | 
| originalartist | TOPE | 
| originalyear | TORY | 
| performersortorder | TSOP | 
| producednotice | TPRO | 
| radioowner | TRSO | 
| radiostationname | TRSN | 
| recordingdates | TRDA | 
| setsubtitle | TSST | 
| time | TIME | 
| title | TIT2 | 
| titlesortorder | TSOT | 
| track | TRCK | 
| version | TIT3 | 
| year | TYER | 
Time Frames¶
[From the mutagen docs] Time fields take the form of YYYY-MM-DD HH:MM:SS Or some partial form (YYYY-MM-DD HH, YYYY, etc.). puddletag supports reading from and writing to:
| puddletag field | ID3v2.4 Frame | 
|---|---|
| encodingtime | TDEN | 
| originalreleasetime | TDOR | 
| releasetime | TDRL | 
| taggingtime | TDTG | 
| year | TDRC | 
URL Frames¶
URL link frames act like text frames, but with two caveats. Only ASCII is allowed and only one value per field is allowed (So even if you try to write multiple values, only the first one will get written).
wwwartist and wwwcommercialinfo are the only URL link frames that allow multiple values per field. Each will be written to a different frame as per the ID3v2.4 standard.
Starting a field name with www: will denote it to be a user-defined URL field. All text following www: will form the description. Eg. from www:homepage homepage will be the description written to the WXXX frame.
| puddletag field | ID3v2.4 Frame | 
|---|---|
| wwwartist | WOAR | 
| wwwcommercialinfo | WCOM | 
| wwwcopyright | WCOP | 
| wwwfileinfo | WOAF | 
| wwwpayment | WPAY | 
| wwwpublisher | WPUB | 
| wwwradio | WORS | 
| wwwsource | WOAS | 
Paired Frames¶
The following are called paired frames due to their values being represented as paired items. Eg. the involvedpeople tag could list the people involved in the band of whatever song you’re trying to tag, like Billy Taylor:Piano;Chester Bennington:Vocals;Ratatat:Instruments (note that spaces are significant). Items in a pair are separated with a colon (:), with pairs separated by a semi-colon(;) (like I just did). Although Mp3tag allows the writing of multiple paired frames, the ID3 standard doesn’t allow it, therefore mutagen doesn’t, hence puddletag refrains from writing multiple paired frames. So erm…store all your stuff in one frame if you don’t mind. Thanks.
Here are the puddletag supported frames:
| puddletag field | ID3v2.4 Frame | 
|---|---|
| involvedpeople | TIPL | 
| musiciancredits | TMCL | 
Misc Frames¶
These frames are handled differently from those previously discussed, so I’ve put them all in misc.
field: playcount, frame: PCNT¶
The PCNT frame stores the number of times the file has been played. This frame is usually only used by media players. Although it’s been superseded by:
field: popularimeter, frame: POPM¶
This frame stores three values: an email, rating and playcount separated by a colon as in cpuddle@unregistered.com:12:3. If playcount isn’t found in an existing field it’ll be added.
field: ufid, frame: UFID¶
UFID stands for Unique File Identifier. It’s a single-valued field shown in puddletag as ufid:owner eg. ufid:musicbrainz.org (the MusicBrainz tag source writes the MusicBrainz Track ID to this field). Only values that can be decoded to UTF-8 will be editable.
field: rgain, frame: RVA2¶
Replaygain, also know as Relative Volume Adjustment info is stored in the RVA2 Frame. The field name in puddletag will take the rgain:description. You’re likely to encounter either rgain:track or rgain:album as these are used by media players to store Replaygain info. Values are of the forme channel:gain:peak where peak is a floating point number between 0 and 1.
field: unsyncedlyrics, frame: USLT¶
Unsynced Lyrics frames store lyrics. Values should take the form Language|Description|Lyrics, where Language corresponds to three-letter language abbreviation as listed in ISO-639-2. If only text is entered, the language XXX will be used. If only one ‘|’ is found in the text, it’ll be assumed that the Language and Lyrics were entered.