#pygn
pygn (pronounced "pigeon") is a simple Python client for the Gracenote Music API, which can retrieve Artist, Album and Track metadata with the most common options.
pygn allows you to look up artists, albums, and tracks in the Gracenote database, and returns a number of metadata fields, including:
- Basic metadata like Artist Name, Album Title, Track Title
- Descriptors like Genre, Origin, Mood, Tempo
- Related content like Album Art, Artist Image, Biographies
##Installation
Since pygn is (so far) contained in a single Python file, no installer is provided. Simply copy pygn.py to your working directory, or to your Python site-packages/dist-packages directory, and call 'import pygn'!
##Getting Started
You will need a Gracenote Client ID to use this module. Please visit https://developer.gracenote.com to get yours.
Each installed application also needs to have a User ID, which may be obtained by registering your Client ID with the Gracenote API. To do this, do:
import pygn
clientID = '*******-************************' # Enter your Client ID here
userID = pygn.register(clientID)
This registration should be done only once per application to avoid hitting your API quota (i.e. definitely do NOT do this before every query). The userID can be stored in persistent storage (e.g. on the filesystem) and used for all subsequent pygn function calls.
Once you have your Client ID and User ID, you can start making queries.
To search for the Kings of Convenience track "Homesick" from their album "Riot On An Empty Street", do:
metadata = pygn.searchTrack(clientID, userID, 'Kings Of Convenience', 'Riot On An Empty Street', 'Homesick')
The returned gnmetadata object is a Python dict containing multiple metadata fields.
{
"album_art_url": "https://web.content.cddbp.net/cgi-bin/content-thin?id=8D43DA988315CC43&client=3675392&class=cover&origin=front&size=medium&type=image/jpeg&tag=02EtNKHYoxbmX81TvhkE3fi9TqbeRGUtLtq0..8BHgwpPbeO8Qr83xuw",
"album_artist_name": "Kings Of Convenience",
"album_gnid": "59247312-2ED193587EF0504C7A0C416ED66DA962",
"album_title": "Riot On An Empty Street",
"album_year": "2004",
"artist_bio_url": "https://web.content.cddbp.net/cgi-bin/content-thin?id=22DA84B96832BF4F&client=3675392&class=biography&type=text/plain&tag=02UUefhCnS5BJ-esbokzJX7W22Yod1K16ehzV.cY7h1ReCwW.77g89DQ",
"artist_era": {
"1": {
"ID": "29483",
"TEXT": "2000's"
}
},
"artist_image_url": "https://web.content.cddbp.net/cgi-bin/content-thin?id=797304D567E8970F&client=3675392&class=image&size=medium&type=image/jpeg&tag=02pI.mKJmjXrmvZQ6Q18X8klZChtwp7oGtZDaoINl3OcH7owTe-soMkw",
"artist_origin": {
"1": {
"ID": "29896",
"TEXT": "Scandinavia"
},
"2": {
"ID": "29990",
"TEXT": "Norway"
}
},
"artist_type": {
"1": {
"ID": "29422",
"TEXT": "Male"
},
"2": {
"ID": "29432",
"TEXT": "Male Duo"
}
},
"genre": {
"1": {
"ID": "25312",
"TEXT": "Alternative & Punk"
},
"2": {
"ID": "35477",
"TEXT": "Indie Rock"
},
"3": {
"ID": "25460",
"TEXT": "Indie Pop"
}
},
"mood": {
"1": {
"ID": "42949",
"TEXT": "Melancholy"
},
"2": {
"ID": "65343",
"TEXT": "Light Melancholy"
}
},
"review_url": "https://web.content.cddbp.net/cgi-bin/content-thin?id=4045DA976DB1DEFA&client=3675392&class=review&type=text/plain&tag=02z.AZyq.HafSMqFFd.hLuKZpc.Vz8gOn-1fx8bdQM5Rih9jAIIEO9Mg",
"tempo": {
"1": {
"ID": "34283",
"TEXT": "Medium Tempo"
},
"2": {
"ID": "34289",
"TEXT": "Medium Slow"
},
"3": {
"ID": "34311",
"TEXT": "60s"
}
},
"track_artist_name": "",
"track_gnid": "59247313-E198021B46C38679362C35619E93396B",
"track_number": "1",
"track_title": "Homesick"
}
Note that URLs to related content (e.g. Album Art, Artist Image, etc) are not valid forever, so your application should download the content you want relatively soon after the lookup and cache it locally.
If you don't know which album a track is on (or don't care which album version you get), you can simply leave that parameter blank:
metadata = pygn.searchTrack(clientID, userID, 'Kings Of Convenience', '', 'Homesick')
pygn also provides convenience functions to look up just an Artist or just an Album. Doing:
metadata = pygn.searchArtist(clientID, userID, 'CSS')
will return the same gnmetadata object with metadata for the top album by CSS (which happens to be 'Cansei De Ser Sexy' at time of writing), with track-specific fields being blank
Calling:
metadata = pygn.searchAlbum(clientID, userID, 'Jaga Jazzist', 'What We Must')
will return a gnmetadata object with metadata for Jaga Jazzist's "What We Must" album, again with track-specific fields empty