ID3
ID3 is a metadata container most often used in conjunction with the MP3 audio file format. It allows information such as the title, artist, album, track number, and other information about the file to be stored in the file itself.
There are two unrelated versions of ID3: ID3v1 and ID3v2. ID3v1 takes the form of a 128-byte segment at the end of an MP3 file containing a fixed set of data fields. ID3v1.1 is a slight modification which adds a "track number" field at the expense of a slight shortening of the "comment" field. ID3v2 is structurally very different from ID3v1, consisting of an extensible set of "frames" located at the start of the file, each with a frame identifier and one piece of data. 83 types of frames are declared in the ID3v2.4 specification, and applications can also define their own types. There are standard frames for containing cover art, BPM, copyright and license, lyrics, and arbitrary text and URL data, as well as other things. Three versions of ID3v2 have been documented, each of which has extended the frame definitions.
ID3 is a de facto standard for metadata in MP3 files; no standardization body was involved in its creation nor has such an organization given it a formal approval status. It competes with the APE tag in this arena.
Lyrics3v1 and Lyrics3v2 were tag standards implemented before ID3v2, for adding lyrics to mp3 files. The difference with ID3v2 is that Lyrics3 is always on the end of an MP3 file, after the ID3v1 tag.
ID3v1
The MP3 standard did not include a method for storing file metadata. In 1996 Eric Kemp had the idea to add a small chunk of data to the audio file, thus solving the problem. The method, now known as ID3v1, quickly became the de facto standard for storing metadata in MP3s.The ID3v1 tag occupies 128 bytes, beginning with the string TAG 128 bytes from the end of the file. The tag was placed at the end of the file to maintain compatibility with older media players. Some players would play a small burst of static when they read the tag, but most ignored it, and almost all modern players will correctly skip it. This tag allows 30 bytes each for the title, artist, album, and a "comment", four bytes for the year, and a byte to identify the genre of the song from a predefined list of 80 values.
One improvement to ID3v1 was made by Michael Mutschler in 1997. Since the comment field was too small to write anything useful, he decided to trim it by two bytes and use those two bytes to store the track number. Such tags are referred to as ID3v1.1.
ID3v1 and ID3v1.1
Strings are either space- or zero-padded. Unset string entries are filled using an empty string. ID3v1 is 128 bytes long.Field | Length | Description |
header | 3 | "TAG" |
title | 30 | 30 characters of the title |
artist | 30 | 30 characters of the artist name |
album | 30 | 30 characters of the album name |
year | 4 | A four-digit year |
comment | 28 or 30 | The comment. |
zero-byte | 1 | If a track number is stored, this byte contains a binary 0. |
track | 1 | The number of the track on the album, or 0. Invalid, if previous byte is not a binary 0. |
genre | 1 | Index in a list of genres, or 255 |
ID3v1 pre-defines a set of genres denoted by numerical codes. Winamp extended the list by adding more genres in its own music player, which were later adopted by others. However, support for the extended Winamp list is not universal. In some cases, only the genres up to 125 are supported.
Enhanced TAG
The Enhanced tag is an extra data block before an ID3v1 tag, which extends the title, artist and album fields to 60 bytes each, offers a freetext genre, a one-byte speed and the start and stop time of the music in the MP3 file, e.g., for fading in. If none of the fields are used, it will be automatically omitted.Some programs supporting ID3v1 tags can read the extended tag, but writing may leave stale values in the extended block. The extended block is not an official standard and is only supported by few programs, not including XMMS or Winamp. The Enhanced tag is sometimes referred to as the "extended" tag.
The Enhanced tag is 227 bytes long, and placed before the ID3v1 tag.
Field | Length | Description |
header | 4 | "TAG+" |
title | 60 | 60 characters of the title |
artist | 60 | 60 characters of the artist name |
album | 60 | 60 characters of the album name |
speed | 1 | 0=unset, 1=slow, 2= medium, 3=fast, 4=hardcore |
genre | 30 | A free-text field for the genre |
start-time | 6 | the start of the music as mmm:ss |
end-time | 6 | the end of the music as mmm:ss |
ID3v1.2
ID3v1.2 purpose is to add small improvements to ID3v1.1 informal standard without breaking the ID3v1 informal standardThe ID3v1.2 tag will not cause any issues in legacy decoders/players
Genre list in ID3v1
standard
Number | Genre |
00 | Blues |
01 | Classic rock |
02 | Country |
03 | Dance |
04 | Disco |
05 | Funk |
06 | Grunge |
07 | Hip-Hop |
08 | Jazz |
09 | Metal |
10 | New Age |
11 | Oldies |
12 | Other |
13 | Pop |
14 | Rhythm and Blues |
15 | Rap |
16 | Reggae |
17 | Rock |
18 | Techno |
19 | Industrial |
Number | Genre |
20 | Alternative |
21 | Ska |
22 | Death metal |
23 | Pranks |
24 | Soundtrack |
25 | Euro-Techno |
26 | Ambient |
27 | Trip-Hop |
28 | Vocal |
29 | Jazz & Funk |
30 | Fusion |
31 | Trance |
32 | Classical |
33 | Instrumental |
34 | Acid |
35 | House |
36 | Game |
37 | Sound clip |
38 | Gospel |
39 | Noise |
Number | Genre |
40 | Alternative Rock |
41 | Bass |
42 | Soul |
43 | Punk |
44 | Space |
45 | Meditative |
46 | Instrumental Pop |
47 | Instrumental Rock |
48 | Ethnic |
49 | Gothic |
50 | Darkwave |
51 | Techno-Industrial |
52 | Electronic |
53 | Pop-Folk |
54 | Eurodance |
55 | Dream |
56 | Southern Rock |
57 | Comedy |
58 | Cult |
59 | Gangsta |
Number | Genre |
60 | Top 40 |
61 | Christian Rap |
62 | Pop/Funk |
63 | Jungle |
64 | Native US |
65 | Cabaret |
66 | New Wave |
67 | Psychedelic |
68 | Rave |
69 | Show tunes |
70 | Trailer |
71 | Lo-Fi |
72 | Tribal |
73 | Acid Punk |
74 | Acid Jazz |
75 | Polka |
76 | Retro |
77 | Musical |
78 | Rock ’n’ Roll |
79 | Hard rock |
Winamp Extended List
Genres 142–147 were added in the 1 June 1998 release of Winamp 1.91; genres 148–191 were added in Winamp 5.6.Number | Genre |
80 | Folk |
81 | Folk-Rock |
82 | National Folk |
83 | Swing |
84 | Fast Fusion |
85 | Bebop |
86 | Latin |
87 | Revival |
88 | Celtic |
89 | Bluegrass |
90 | Avantgarde |
91 | Gothic Rock |
92 | Progressive Rock |
93 | Psychedelic Rock |
94 | Symphonic Rock |
95 | Slow rock |
96 | Big Band |
97 | Chorus |
98 | Easy Listening |
99 | Acoustic |
Number | Genre |
100 | Humour |
101 | Speech |
102 | Chanson |
103 | Opera |
104 | Chamber music |
105 | Sonata |
106 | Symphony |
107 | Booty bass |
108 | Primus |
109 | Porn groove |
110 | Satire |
111 | Slow jam |
112 | Club |
113 | Tango |
114 | Samba |
115 | Folklore |
116 | Ballad |
117 | Power ballad |
118 | Rhythmic Soul |
119 | Freestyle |
Number | Genre |
120 | Duet |
121 | Punk Rock |
122 | Drum solo |
123 | A cappella |
124 | Euro-House |
125 | Dancehall |
126 | Goa |
127 | Drum & Bass |
128 | Club-House |
129 | Hardcore Techno |
130 | Terror |
131 | Indie |
132 | BritPop |
133 | Negerpunk |
134 | Polsk Punk |
135 | Beat |
136 | Christian Gangsta Rap |
137 | Heavy Metal |
138 | Black Metal |
139 | Crossover |
Number | Genre |
140 | Contemporary Christian |
141 | Christian rock |
142 | Merengue |
143 | Salsa |
144 | Thrash Metal |
145 | Anime |
146 | Jpop |
147 | Synthpop |
148 | Abstract |
149 | Art Rock |
150 | Baroque |
151 | Bhangra |
152 | Big beat |
153 | Breakbeat |
154 | Chillout |
155 | Downtempo |
156 | Dub |
157 | EBM |
158 | Eclectic |
159 | Electro |
Number | Genre |
160 | Electroclash |
161 | Emo |
162 | Experimental |
163 | Garage |
164 | Global |
165 | IDM |
166 | Illbient |
167 | Industro-Goth |
168 | Jam Band |
169 | Krautrock |
170 | Leftfield |
171 | Lounge |
172 | Math Rock |
173 | New Romantic |
174 | Nu-Breakz |
175 | Post-Punk |
176 | Post-Rock |
177 | Psytrance |
178 | Shoegaze |
179 | Space Rock |
Number | Genre |
180 | Trop Rock |
181 | World Music |
182 | Neoclassical |
183 | Audiobook |
184 | Audio theatre |
185 | Neue Deutsche Welle |
186 | Podcast |
187 | Indie-Rock |
188 | G-Funk |
189 | Dubstep |
190 | Garage Rock |
191 | Psybient |
ID3v2
In 1998, a new specification called ID3v2 was created by multiple contributors. Although it bears the name ID3, its structure is very different from ID3v1.ID3v2 tags are of variable size, and usually occur at the start of the file, which aids streaming media as the metadata is essentially available as soon as the file starts streaming instead of requiring the entire file to be read first as is the case with ID3v1. ID3v2 tags consist of a number of frames, each of which contains a piece of metadata. For example, the TIT2 frame contains the title, and the WOAR frame contains the URL of the artist's website. Frames can be up to 16MB in length, while total tag size is limited to 256MB. The internationalization problem was solved by allowing the encoding of strings not only in ISO-8859-1, but also in Unicode.
Textual frames are marked with an encoding byte.
$00 – ISO-8859-1.
$01 – UCS-2 encoded Unicode with BOM, in ID3v2.2 and ID3v2.3.
$02 – UTF-16BE encoded Unicode without BOM, in ID3v2.4.
$03 – UTF-8 encoded Unicode, in ID3v2.4.
However, mojibake is still common when using local encodings instead of Unicode. In particular, some Japanese editors are known to use Shift JIS encoding, which usually has disastrous effects: it will not work with any standard-compliant software regardless of local settings, will not work outside Japan, and will not even work on all Japanese computers even with a specifically non-compliant reader.
There are 83 types of frames declared in the ID3v2.4 specification, and applications can also define their own types. There are standard frames for containing cover art,, copyright and license, lyrics, and arbitrary text and URL data, as well as other things.
There are three versions of ID3v2:
;ID3v2.2
;ID3v2.3
;ID3v2.4
ID3v2 rating tag issue
There is a loose de facto standard for implementation of song ratings. Most apps will display 0 to 5 stars for any given song, and how the stars are expressed can vary. For instance, when rating a song in iTunes, the rating is not embedded in the tag in the music file, but is instead stored in a separate database that contains all of the iTunes metadata. Other media players can embed rating tags in music files, but not necessarily the same way, so as a result a song which is rated on one media player sometimes won't display the rating the same way, or at all, when played on other software or mobile device.However, there is a "" frame in the ID3v2 specification meant for this purpose. The frame is called POPM and Windows Explorer, Windows Media Player, Winamp, foobar2000, MediaMonkey, and other software all map roughly the same ranges of 0–255 to a 0–5 stars value for display.
The following list details how Windows Explorer reads and writes the POPM frame:
- 224–255 = 5 stars when READ with Windows Explorer, writes 255
- 160–223 = 4 stars when READ with Windows Explorer, writes 196
- 096-159 = 3 stars when READ with Windows Explorer, writes 128
- 032-095 = 2 stars when READ with Windows Explorer, writes 64
- 001-031 = 1 star when READ with Windows Explorer, writes 1
Windows Media Player 9 Series | 255 | 0
The 0 is the play counter portion of POPM as per the ID3v2 POPM specification, which is not to be confused or conflated with the PCNT frame, which is a separate frame meant entirely for playcounts. If an app supports granularity however, it should write 1 for one full star, and then 2–31 would be granular points under one full star. Notably, the ID string Windows uses is not an email address, as called for in the specifications. Further, Windows Explorer and Windows Media Player up to and including Windows 7 and WMP 12 contain a bug such that, if one were to use them to rate files, any Replay Gain tags one would have will be corrupted. WMP also writes the same values as described above, and reads the same way as well, EXCEPT for the cutoff between 4 and 5 stars, which is slightly different and basically of no consequence. WMP uses 221/222 instead, for .
ID3v2 chapters
The ID3v2 Chapter Addendum was published in December 2005 but is not widely supported as yet. It allows users to jump easily to specific locations or chapters within an audio file and can provide a synchronized slide show of images and titles during playback. Typical applications include Enhanced podcasts and it can be used in ID3v2.3 or ID3v2.4 tags.ID3v2 embedded image extension
The metadata can contain an "Attached Picture" ID3 frame containing an image. A field in this frame can indicate the picture type. The following types are defined:
$00 Other
$01 32x32 pixels 'file icon'
$02 Other file icon
$03 Cover
$04 Cover
$05 Leaflet page
$06 Media
$07 Lead artist/lead performer/soloist
$08 Artist/performer
$09 Conductor
$0A Band/Orchestra
$0B Composer
$0C Lyricist/text writer
$0D Recording Location
$0E During recording
$0F During performance
$10 Movie/video screen capture
$11 A bright coloured fish
$12 Illustration
$13 Band/artist logotype
$14 Publisher/Studio logotype
ID3v2 frame specification
Notes:Version 2.4 of the specification prescribes that all text fields can contain multiple values separated by a null character. The null character varies by character encoding.
Editing ID3 tags
ID3 tags may be edited in a variety of ways. On some platforms the file's properties may be edited by viewing extended information in the file manager. Additionally most audio players allow editing single or groups of files. Editing groups of files is often referred to as "batch tagging". There are also specialized applications, called taggers, which concentrate specifically on editing the tags and related tasks. Some, such as puddletag offer advanced features such as advanced batch tagging or editing based on regular expressions.Non-MP3-implementation and alternatives
ID3 tags were designed with MP3 in mind, so they would work without problems with MP3 and MP3Pro files. However, the tagsets are an independent part of the MP3 file and should be usable elsewhere. In practice, the only other formats which widely uses ID3v2 tags are AIFF and WAV. In AIFF the tag is stored inside an IFF chunk named "ID3". Windows media ASF files have their own tagging formats but also support ID3 Tags embedded as attributes.MP4 also allows the embedding of an ID3 tag.