2017-01-24 06:14:29 +00:00
# Ironic Redistribution System
2016-12-11 00:26:11 +00:00
[![License: GNU ](https://img.shields.io/badge/License-GNU-yellow.svg )](http://www.gnu.org/licenses/gpl.html)
2016-12-20 16:20:39 +00:00
[![PyPI ](https://img.shields.io/badge/PyPi-Python_3.x-blue.svg )](https://pypi.python.org/pypi/irs)
2016-07-08 04:37:40 +00:00
2017-01-26 05:34:11 +00:00
< em > Spotify playlists are now downloadable! Just use the `-u` flag and your username!</ em >
2017-01-24 06:14:29 +00:00
An ironically named program to download audio from youtube and then parse metadata for the downloaded file.
2016-12-11 00:26:11 +00:00
___
### Usage and Examples
2017-01-26 04:57:56 +00:00
To download Spotify playlists, you need to supply client_ids. To do this, you'll want to create an application [here ](https://developer.spotify.com/my-applications/#!/applications/create ). Once you've done that, you'll want to copy your 'client id' and your 'client secret' into the config file and their corresponding lines. To find the config file run this command: `irs -C` . If that's all working, enter the name of the playlist you would like to download like this:
```bash
irs -p "Brain Food"
2017-01-24 05:49:05 +00:00
```
2017-01-26 05:34:11 +00:00
If you are looking for one of *your* playlists, you'll want to use the `-u` flag and put your username in:
```bash
irs -u "prakkillian"
```
2017-01-26 04:57:56 +00:00
If you download a specific song, you'll want to use the `-s` and `-a` flag.
```bash
2017-01-24 05:49:05 +00:00
irs -a "David Bowie" -s "Ziggy Stardust"
```
2017-01-26 04:57:56 +00:00
To download an entire album, you'll want to use the `-A` flag. If the album you want can't be found, run it with the `-a` flag for some more specification.
```bash
irs -A "Sadnecessary" # -a "Milky Chance"
2017-01-24 05:49:05 +00:00
```
2017-01-26 05:34:11 +00:00
[![asciicast ](https://asciinema.org/a/5aijmkdux6nk8ckhke0jmzlyq.png )](https://asciinema.org/a/5aijmkdux6nk8ckhke0jmzlyq?speed=3& autoplay=true)
2017-01-24 05:49:05 +00:00
[![asciicast ](https://asciinema.org/a/8kb9882j4cbtd4hwbsbb7h0ia.png )](https://asciinema.org/a/8kb9882j4cbtd4hwbsbb7h0ia?speed=3)
Full usage:
2016-12-11 00:26:11 +00:00
```
2016-12-15 06:45:07 +00:00
usage:
irs (-h | -v)
2016-12-20 03:45:12 +00:00
irs [-l]
2017-01-26 04:57:56 +00:00
irs -p PLAYLIST [-c COMMAND] [-l]
irs -A ALBUM [-c COMMAND] [-l]
irs -a ARTIST -s SONG [-c COMMAND] [-l]
2016-12-11 00:26:11 +00:00
2016-12-15 06:45:07 +00:00
Options:
2016-12-11 00:26:11 +00:00
-h, --help show this help message and exit
2016-12-15 02:38:39 +00:00
-v, --version Display the version and exit.
2017-01-26 04:57:56 +00:00
-A ALBUM, --album ALBUM
Search spotify for an album.
-p PLAYLIST, --playlist PLAYLIST
Search spotify for a playlist.
2017-01-26 05:34:11 +00:00
-u USER, --user USER Download a user playlist.
2016-12-15 06:45:07 +00:00
-c COMMAND, --command COMMAND
Run a background command with each song's location.
Example: `-c "rhythmbox %(loc)s"`
2016-12-11 00:26:11 +00:00
-a ARTIST, --artist ARTIST
2017-01-26 04:57:56 +00:00
Specify the artist name. Only needed for -s/--song
-s SONG, --song SONG Specify song name of the artist. Must be used with
-a/--artist
2016-12-20 03:45:12 +00:00
-l, --choose-link If supplied, will bring up a console choice for what
link you want to download based off a list of titles.
2016-12-15 06:45:07 +00:00
```
2017-01-26 05:01:18 +00:00
Make a note that capitalization and spelling matters a lot in this program.
2016-12-13 03:46:24 +00:00
2016-12-11 00:26:11 +00:00
___
### Installation
2016-12-20 16:19:17 +00:00
Please note that it currently is only usable in `Python 3.x` . Almost all dependencies are automatically installed by pip, but `youtube_dl` still needs `ffmpeg` to convert video to audio, so for Windows, you can install [`Scoop` ](http://scoop.sh/ ) and then just do:
2016-12-11 07:46:46 +00:00
```
2017-01-26 04:57:56 +00:00
scoop install ffmpeg
2016-12-11 07:46:46 +00:00
```
2016-12-20 16:19:17 +00:00
For OSX, you can use [`Brew` ](http://brew.sh/ ) to install `ffmpeg` :
2016-12-11 07:46:46 +00:00
```
2017-01-26 04:57:56 +00:00
brew install ffmpeg
2016-12-11 07:46:46 +00:00
```
2016-12-20 16:19:17 +00:00
And then for Ubuntu:
2016-12-11 07:46:46 +00:00
```
2017-01-26 04:57:56 +00:00
sudo apt-get install ffmpeg
2016-12-11 07:46:46 +00:00
```
2016-12-13 03:46:24 +00:00
Most other linux distros have `ffmpeg` or `libav-tools` in their package manager repos, so you can install one or the other for other distros.
2016-12-20 03:50:24 +00:00
Finally, install it!
```
2017-01-26 04:57:56 +00:00
pip install irs
2016-12-20 03:50:24 +00:00
```
2017-01-24 06:14:29 +00:00
2017-01-26 04:57:56 +00:00
### Why the name?
As an acronym, it spells IRS. I think this is breathtakingly hilarious because the Internal Revenue Service (also the IRS) takes away, while my program gives. I'm so funny. You can tell that I'll get laid in college.
2017-01-24 06:14:29 +00:00
### Wishlist
- [x] Finds album based off of song name and artist
- [x] Full album downloading
- [x] Album art metadata correctly displayed
- [x] Playlist downloading
2017-01-26 04:57:56 +00:00
- [x] Spotify playlist downloading
2017-01-24 06:14:29 +00:00
- [ ] GUI/Console interactive version - < em > In progress</ em >
- [ ] 100% success rate for automatic song choosing