ID3 library for Go
Go to file
Michael Yang 9163b6c404 Move file end check to helper method 2014-01-10 14:54:24 -05:00
v1 Replace fileEndFlag with os package constant 2014-01-10 14:48:28 -05:00
v2 Parse header flags 2014-01-10 00:43:42 -05:00
LICENSE Initial commit 2013-12-19 15:20:17 -05:00
README.md Update README 2014-01-08 00:24:31 -05:00
id3.go Move file end check to helper method 2014-01-10 14:54:24 -05:00
id3_test.go Add general test 2014-01-09 00:46:17 -05:00
test.mp3 Add general test 2014-01-09 00:46:17 -05:00
util.go Move file end check to helper method 2014-01-10 14:54:24 -05:00

README.md

id3

ID3 library for Go.

Supported formats:

  • ID3v1
  • ID3v2.2
  • ID3v2.3

Install

The platform ($GOROOT/bin) "go get" tool is the best method to install.

go get github.com/mikkyang/id3-go

This downloads and installs the package into your $GOPATH. If you only want to recompile, use "go install".

go install github.com/mikkyang/id3-go

Usage

An import allows access to the package.

import (
    id3 "github.com/mikkyang/id3-go"
)

Version specific details can be accessed through the subpackages.

import (
    "github.com/mikkyang/id3-go/v1"
    "github.com/mikkyang/id3-go/v2"
)

Opening a File

To access the tag of a file, first open the file using the package's Open function.

mp3File, err := id3.Open("All-In.mp3")

It's also a good idea to ensure that the file is closed using defer.

defer mp3File.Close()

Accessing Information

Some commonly used data have methods in the tag for easier access. These methods are for Title, Artist, Album, Year, Genre, and Comments.

mp3File.SetArtist("Okasian")
fmt.Println(mp3File.Artist())

ID3v2 Frames

v2 Frames can be accessed directly by using the Frame or Frames method of the file, which return the first frame or a slice of frames as Framer interfaces. These interfaces allow read access to general details of the file.

lyricsFrame := mp3File.Frame("USLT")
lyrics := lyricsFrame.String()

If more specific information is needed, or frame-specific write access is needed, then the interface must be cast into the appropriate underlying type. The example provided does not check for errors, but it is recommended to do so.

lyricsFrame := mp3File.Frame("USLT").(*v2.UnsynchTextFrame)