2018-01-25 10:09:20 +00:00
|
|
|
Twitch Downloader
|
|
|
|
=================
|
|
|
|
|
2020-09-03 10:56:08 +00:00
|
|
|
CLI tool for downloading videos from twitch.tv
|
2018-01-25 10:09:20 +00:00
|
|
|
|
2020-09-03 10:56:08 +00:00
|
|
|
Inspired by [youtube-dl](https://youtube-dl.org/) but improves upon it by using
|
|
|
|
multiple concurrent connections to make the download faster.
|
2019-04-30 11:36:32 +00:00
|
|
|
|
|
|
|
Resources
|
|
|
|
---------
|
|
|
|
|
2019-04-30 11:45:11 +00:00
|
|
|
* Homepage: https://github.com/ihabunek/twitch-dl
|
|
|
|
* Issues: https://github.com/ihabunek/twitch-dl/issues
|
|
|
|
* Python package: https://pypi.org/project/twitch-dl/
|
2019-04-30 11:36:32 +00:00
|
|
|
|
2020-05-29 11:57:02 +00:00
|
|
|
Requirements
|
|
|
|
------------
|
|
|
|
|
|
|
|
* Python 3.5+
|
2020-09-03 10:56:08 +00:00
|
|
|
* [ffmpeg](https://ffmpeg.org/download.html), installed and on the system path
|
|
|
|
|
|
|
|
Installation
|
|
|
|
------------
|
|
|
|
|
|
|
|
### Download standalone archive
|
|
|
|
|
|
|
|
Go to the [latest release](https://github.com/ihabunek/twitch-dl/releases/latest)
|
|
|
|
and download the `twitch-dl.<version>.pyz` archive.
|
|
|
|
|
|
|
|
Run the archive by either:
|
|
|
|
|
|
|
|
a) passing it to python:
|
|
|
|
|
|
|
|
```
|
2020-11-10 09:48:21 +00:00
|
|
|
python3 twitch-dl.1.13.0.pyz --help
|
2020-09-03 10:56:08 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
b) making it executable and invoking it directly (linux specific):
|
|
|
|
|
|
|
|
```
|
2020-11-10 09:48:21 +00:00
|
|
|
chmod +x twitch-dl.1.13.0.pyz
|
|
|
|
./twitch-dl.1.13.0.pyz --help
|
2020-09-03 10:56:08 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Feel free to rename the archive to something more managable, like `twitch-dl`.
|
|
|
|
|
|
|
|
To upgrade to a newer version, repeat the process with the newer release.
|
|
|
|
|
|
|
|
### From PYPI using pipx
|
|
|
|
|
|
|
|
**pipx** is a tool which installs python apps into isolated environments, which
|
|
|
|
prevents all kinds of problems later so it's the suggested way to install
|
|
|
|
twitch-dl from PYPI.
|
|
|
|
|
|
|
|
Install pipx as described in
|
|
|
|
[pipx install docs](https://pipxproject.github.io/pipx/installation/).
|
|
|
|
|
|
|
|
Install twitch-dl:
|
|
|
|
|
|
|
|
```
|
|
|
|
pipx install twitch-dl
|
|
|
|
```
|
|
|
|
|
|
|
|
Check installation worked:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl --help
|
|
|
|
```
|
|
|
|
|
|
|
|
If twitch-dl executable is not found, check that the pipx binary location (by
|
|
|
|
default `~/.local/bin`) is in your PATH.
|
|
|
|
|
|
|
|
To upgrade twitch-dl to the latest version:
|
|
|
|
|
|
|
|
```
|
|
|
|
pipx install twitch-dl
|
|
|
|
```
|
2020-05-29 11:57:02 +00:00
|
|
|
|
2018-01-25 10:09:20 +00:00
|
|
|
Usage
|
|
|
|
-----
|
|
|
|
|
2021-01-14 21:04:44 +00:00
|
|
|
This section does an overview of available features.
|
2020-11-10 08:38:29 +00:00
|
|
|
|
2021-01-14 21:04:44 +00:00
|
|
|
To see a list of available commands run:
|
2018-01-25 10:09:20 +00:00
|
|
|
|
|
|
|
```
|
2021-01-14 21:04:44 +00:00
|
|
|
twitch-dl --help
|
2018-01-25 10:09:20 +00:00
|
|
|
```
|
|
|
|
|
2021-01-14 21:04:44 +00:00
|
|
|
And to see description and all arguments for a given command run:
|
2018-01-25 10:09:20 +00:00
|
|
|
|
|
|
|
```
|
2021-01-14 21:04:44 +00:00
|
|
|
twitch-dl <command> --help
|
|
|
|
```
|
2018-01-25 10:09:20 +00:00
|
|
|
|
2021-01-14 21:04:44 +00:00
|
|
|
### Print clip or video info
|
2018-01-25 10:09:20 +00:00
|
|
|
|
2021-01-14 21:04:44 +00:00
|
|
|
Videos can be referenced by URL or ID:
|
2018-01-25 10:09:20 +00:00
|
|
|
|
2021-01-14 21:04:44 +00:00
|
|
|
```
|
|
|
|
twitch-dl info 863849735
|
|
|
|
twitch-dl info https://www.twitch.tv/videos/863849735
|
|
|
|
```
|
|
|
|
|
|
|
|
Clips by slug or ID:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl info BusyBlushingCattleItsBoshyTime
|
|
|
|
twitch-dl info https://www.twitch.tv/bananasaurus_rex/clip/BusyBlushingCattleItsBoshyTime
|
|
|
|
```
|
|
|
|
|
|
|
|
Shows info about the video or clip as well as download URLs for clips and
|
|
|
|
playlist URLs for videos.
|
|
|
|
|
|
|
|
### Listing videos
|
|
|
|
|
|
|
|
List recent streams for a given channel:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl videos bananasaurus_rex
|
2018-01-25 10:09:20 +00:00
|
|
|
```
|
|
|
|
|
2020-05-17 12:46:08 +00:00
|
|
|
Use the `--game` option to specify one or more games to show:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl videos --game "doom eternal" --game "cave story" bananasaurus_rex
|
|
|
|
```
|
|
|
|
|
2020-11-10 08:38:29 +00:00
|
|
|
### Downloading videos
|
|
|
|
|
2021-01-14 21:04:44 +00:00
|
|
|
Download a video by ID or URL:
|
2018-01-25 10:09:20 +00:00
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl download 221837124
|
2019-04-30 11:36:32 +00:00
|
|
|
twitch-dl download https://www.twitch.tv/videos/221837124
|
|
|
|
```
|
|
|
|
|
2020-08-07 14:37:37 +00:00
|
|
|
Specify video quality to download:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl download -q 720p 221837124
|
|
|
|
```
|
|
|
|
|
2020-09-29 06:26:40 +00:00
|
|
|
Setting quality to `source` will download the best available quality:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl download -q source 221837124
|
|
|
|
```
|
|
|
|
|
2022-01-23 08:14:40 +00:00
|
|
|
### Overriding file name
|
|
|
|
|
|
|
|
The target filename can be defined by passing the `--output` option followed by
|
|
|
|
the desired file name, e.g. `--output strim.mkv`.
|
|
|
|
|
|
|
|
The filename uses
|
|
|
|
[Python format string syntax](https://docs.python.org/3/library/string.html#format-string-syntax)
|
|
|
|
and may contain placeholders in curly braces which will be replaced with
|
|
|
|
relevant information tied to the downloaded video.
|
|
|
|
|
|
|
|
The supported placeholders are:
|
|
|
|
|
|
|
|
| Placeholder | Description | Example |
|
|
|
|
| ----------------- | ------------------------------ | ------------------------------ |
|
|
|
|
| `{id}` | Video ID | 1255522958 |
|
|
|
|
| `{title}` | Video title | Dark Souls 3 First playthrough |
|
|
|
|
| `{title_slug}` | Slugified video title | dark_souls_3_first_playthrough |
|
|
|
|
| `{datetime}` | Video date and time | 2022-01-07T04:00:27Z |
|
|
|
|
| `{date}` | Video date | 2022-01-07 |
|
|
|
|
| `{time}` | Video time | 04:00:27Z |
|
|
|
|
| `{channel}` | Channel name | KatLink |
|
|
|
|
| `{channel_login}` | Channel login | katlink |
|
|
|
|
| `{format}` | File extension, see `--format` | mkv |
|
|
|
|
| `{game}` | Game name | Dark Souls III |
|
|
|
|
| `{game_slug}` | Slugified game name | dark_souls_iii |
|
|
|
|
|
|
|
|
|
|
|
|
A couple of examples:
|
|
|
|
|
|
|
|
Pattern: `"{date}_{id}_{channel_login}_{title_slug}.{format}"`<br />
|
|
|
|
Expands to: `2022-01-07_1255522958_katlink_dark_souls_3_first_playthrough.mkv`<br />
|
|
|
|
*This is the default.*
|
|
|
|
|
|
|
|
Pattern: `"{channel} - {game} - {title}.{format}"`<br />
|
|
|
|
Expands to: `KatLink - Dark Souls III - Dark Souls 3 First playthrough.mkv`
|
|
|
|
|
2020-11-10 08:38:29 +00:00
|
|
|
### Listing clips
|
|
|
|
|
|
|
|
List clips for the given period:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl clips bananasaurus_rex --period last_week
|
|
|
|
```
|
|
|
|
|
|
|
|
Supported periods are: `last_day`, `last_week`, `last_month`, `all_time`.
|
|
|
|
|
|
|
|
For listing a large number of clips, it's nice to page them:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl clips bananasaurus_rex --period all_time --limit 10 --pager
|
|
|
|
```
|
|
|
|
|
|
|
|
This will show 10 clips at a time and ask to continue.
|
|
|
|
|
|
|
|
### Downloading clips
|
|
|
|
|
2020-04-11 14:07:17 +00:00
|
|
|
Download a clip by slug or URL:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl download VenomousTameWormHumbleLife
|
|
|
|
twitch-dl download https://www.twitch.tv/bananasaurus_rex/clip/VenomousTameWormHumbleLife
|
|
|
|
```
|
|
|
|
|
2020-08-07 14:37:37 +00:00
|
|
|
Specify clip quality to download:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl download -q 720 VenomousTameWormHumbleLife
|
|
|
|
```
|
|
|
|
|
|
|
|
Note that twitch names for clip qualities have no trailing "p".
|
|
|
|
|
2020-11-10 08:38:29 +00:00
|
|
|
### Batch downloading clips
|
|
|
|
|
|
|
|
It's possible to download all clips for a given period:
|
|
|
|
|
|
|
|
```
|
|
|
|
twitch-dl clips bananasaurus_rex --period last_week --download
|
|
|
|
```
|
|
|
|
|
|
|
|
Clips are downloaded in source quality.
|
|
|
|
|
|
|
|
A note about clips
|
|
|
|
------------------
|
|
|
|
|
|
|
|
Currently it doesn't seem to be possible to get a list of clips ordered by time
|
|
|
|
of creation, only by view count. Clips with the same view count seem to be
|
|
|
|
returned in random order. This can break paging resulting in duplicate clips
|
|
|
|
listed or clips missed.
|
|
|
|
|
|
|
|
When batch downloading a large number of clips (over 100), it's possible that
|
|
|
|
some will be missed.
|
|
|
|
|
2020-09-29 08:57:28 +00:00
|
|
|
Temporary files
|
|
|
|
---------------
|
|
|
|
|
|
|
|
By default, twitch-dl will download VODs to your systems temp dir (e.g. `/tmp/`
|
|
|
|
on Linux). To change the location where the files are downloaded you can set
|
|
|
|
the `TMP` environment variable, e.g.
|
|
|
|
|
|
|
|
```
|
|
|
|
TMP=/my/tmp/path/ twitch-dl download 221837124
|
|
|
|
```
|
|
|
|
|
2019-04-30 11:36:32 +00:00
|
|
|
Man page
|
|
|
|
--------
|
|
|
|
|
|
|
|
Building the man page for twitch-dl requires scdoc.
|
|
|
|
|
|
|
|
The source is in ``twitch-dl.1.scd``, and you can build it by running:
|
|
|
|
|
|
|
|
```
|
|
|
|
make man
|
2018-01-25 10:09:20 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
License
|
|
|
|
-------
|
|
|
|
|
2020-09-03 10:56:08 +00:00
|
|
|
Copyright 2018-2020 Ivan Habunek <ivan@habunek.com>
|
2018-01-25 10:09:20 +00:00
|
|
|
|
|
|
|
Licensed under the GPLv3: http://www.gnu.org/licenses/gpl-3.0.html
|