This command line tool accompanies Long & Eveland (forthcoming) as a means for others to get at the same or similar underlying data plus some other useful goodies. In short, the tool does the following:
- Scrapes historical Billboard charts (songs and albums) for specified genres.
- For albums, uses Discogs and/or Spotify to find tracklists.
- Searches for and stores lyrics for songs found on Billboard charts at MetroLyrics and Wikia.
- Grabs additional data, like audio qualities, via the Spotify API.
This is all stored in a SQLite database.
This app requires Ruby, a widely-used programming language that works on virtually all commonly used operating systems. There is more detailed information here, but I'll give a few suggestions.
I suggest installing Ruby via rvm
, a command line program that allows you to
manage multiple Ruby installations at once and, most important, makes it easy
to download a specifiy Ruby version. More details at RVM's website.
I do not believe the built-in Ruby on macOS will work. This has only been tested with Ruby 2.4.3 and I suggest you find a way to install that version of Ruby.
Windows users are best off going to the Ruby Installer site and choosing the 2.4.3 installer (or whichever version offered that begins with 2.4).
Another alternative for Windows users is to use the Windows Subsystem for Linux, which gives you a Linux (typically Ubuntu) shell built into Windows. In that case, follow the instructions above for Linux installation of Ruby/RVM. Recent development of this app has used this approach.
Download this repository. Now it's installed :)
Open up a terminal (or on Windows, command prompt) and set the working
directory to wherever you downloaded this repository. First, install
the bundler
gem.
gem install bundler
Then use bundler
to install all the other gems this tool depends on.
bundler install
If there are problems, one option is to run bundler update
instead.
This tool can do quite a few things and you probably don't want to do
them all at once. The config.yaml
file is where you control what
this library does on each run. It is mostly self-explanatory, but
the idea here is that you don't need to scrape the Billboard charts
more than once (unless adding new songs/genres/years) and you might
want to customize how the lyric search is done, how you deal with
metadata and so on.
To use Spotify, you will need to create an "application" and get the
associated keys with Spotify. Just follow
this link, sign in
or create a Spotify account, and create an app. This doesn't mean you
program an app, just give a name to the authentication keys that Spotify
provides. You can then copy them to the appropriate places in
config.yaml
.
To use Discogs, which if you don't use Spotify will be necessary to
get tracklists for albums, go to their
API site, click "Create an App",
then make your account and get the required authentication token. Put
that into config.yaml
.
A note about genres:
I wrote this for a specific purpose and therefore it does not automatically handle every single Billboard chart. The genres tested to work are the following:
Both singles and albums:
- Country
- Rock
- R&B/hip hop
- Dance/electronic
- Rap
- Latin
- Christian
Singles only: Pop
Albums only:
- Blues
- Classical
- Jazz
- New Age
- Reggae
But if you include the verbatim URL slug as a genre in config.yaml
,
it will probably work. Let's take, for example, Billboard's K-Pop
charts. The URL for these charts goes like this:
https://www.billboard.com/charts/billboard-korea-k-pop-100
If you include billboard-korea-k-pop-100
as one of the genres under songs:
in config.yaml
,
the charts will be scraped successfully. The same should go for
any other singles or albums genre.
Using the command line, assuming you followed the installation instructions, enter the following command while your session is in this repository's folder:
ruby main.rb
The tool will regularly provide updates on its progress. Be warned that it can take a very long time depending on what you ask it to do. It probably ran for more than 24 hours straight to do all the necessary data collection for the publication associated with this tool.
All the resulting data is stored in a SQLite database in the path you specify
in config.yaml
. You will need to know something about SQL to get the data
into other formats. Unfortunately, this is just the only efficient way to store
relational data that would be absolutely huge if we stored it in a format in
which each Billboard entry had all of the song's information.
I like DB Browser as a cross platform GUI for exploring SQLite databases. You can try out select statements and export to CSV and similar formats as needed. I have included some example SQL statements in the SQL Examples file.
Create an issue here on Github or email me at long.1377@osu.edu.
This tool was used for data collection in the following article:
Long, J. A., & Eveland, W. P. (2018). Entertainment use and political ideology: Linking worldviews to media content. Communication Research. Advance online publication. https://doi.org/10.1177/0093650218791011