-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathREADME.Rmd
76 lines (52 loc) · 1.95 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, echo = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "README-"
)
```
[data:image/s3,"s3://crabby-images/ee9dc/ee9dcad48f4fb8db6070864d35ba6357ea17ca4d" alt="CRAN_Status_Badge"](http://cran.r-project.org/package=musicbrainz)
# musicbrainz <img src="man/figures/logo.png" align="right" />
The goal of musicbrainz is to make it easy to call the MusicBrainz Database API from R. Currently API does NOT require authentication for reading the data, however, requests to the database are subject to a rate limit of 1 request/sec. The package utilizes `ratelimitr` to make sure you don't need to worry about exceeding that limit.
## Installation
You can install musicbrainz from github with:
```{r gh-installation, eval = FALSE}
# install.packages("devtools")
devtools::install_github("dmi3kno/musicbrainz")
```
## Example
There are three families of functions in `musicbrainz` package: search, lookup and browse.
### Search
Lets search information about Miles Davis
```{r miles}
library(musicbrainz)
library(dplyr)
miles_df <- search_artists("Miles Davis")
miles_df
```
It looks like the first hit is what we need. We can use `dplyr` to extract the information of interest
```{r id}
miles_id <- miles_df %>%
select(mbid) %>%
slice(1) %>%
pull()
```
### Lookup
Now that we have MusicBrainz id ("mbid") we can call the lookup function.
```{r lookup}
miles_lookup <- lookup_artist_by_id("561d854a-6a28-4aa7-8c99-323e6ce46c2a")
miles_lookup
```
### Browse
We can also browse linked records (such as all releases by Miles Davis).
```{r browse}
miles_releases <- browse_releases_by("artist", "561d854a-6a28-4aa7-8c99-323e6ce46c2a")
miles_releases
```
## References
1. Details of the Musicbrainz database API: https://musicbrainz.org/doc/Development/XML_Web_Service/Version_2
2. Details about rate limits: https://musicbrainz.org/doc/XML_Web_Service/Rate_Limiting