ID3 library for Go
Go to file
Michael Yang 0ff7d46ca8 Remove commonFrames embedded struct 2013-12-30 04:00:14 -05:00
LICENSE Initial commit 2013-12-19 15:20:17 -05:00
README.md Update README 2013-12-22 02:49:01 -05:00
frame.go Fix set frame field size issue 2013-12-30 03:02:28 -05:00
id3.go Remove commonFrames embedded struct 2013-12-30 04:00:14 -05:00
id3v2.go Increase tag header size field when padding is depleted 2013-12-30 03:02:28 -05:00
id3v23.go Make bytes method version specific 2013-12-21 16:31:38 -05:00
util.go Fix set frame field size issue 2013-12-30 03:02:28 -05:00
util_test.go Test byte slice and int conversion 2013-12-29 23:51:30 -05:00

README.md

id3

ID3 library for Go. Work in progress.

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"
)

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 Frames

Some commonly used frames have fields in the file for easier access. These frames are Title, Artist, Album, and Genre.

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

Other Frames

Other frames can be accessed directly by using the Frames field of the file, which is a map, keyed by ID3 frame identifiers, of slices containing Framer interfaces. This interfaces allow read access to general details of the file.

lyricsFrame := mp3File.Frames["USLT"][0]
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.Frames["USLT"][0].(*id3.UnsynchTextFrame)