Have you ever downloaded a Twitch video using YouTube-DL, watched it, and wished you could download the chat too? Now you can.
This console app downloads the chat on a Twitch video and converts it to an SRT file, so you can read chat as subtitles while watching the video. Here's it in action on VLC:
- Q: Why create this when Chat Replay already exists?
- A: Because Twitch Past Broadcasts are deleted after 30 days, and although you can download videos with YouTube-DL, at present you can't download the chat.
- Ensure the .NET Core runtime is on the path.
- Download and unzip the latest release.
In PowerShell (or similar terminal), run dotnet TwitchChatDownloader.dll
to display the help, printed below for convenience:
ERROR(S):
No verb selected.
user Download chat for all of a user's videos.
video Download a single video.
help Display more information on a specific command.
version Display version information.
If you run dotnet TwitchChatDownloader.dll user
, you'll get this help:
ERROR(S):
Required option 'u, username' is missing.
-u, --username Required. The username (for example, https://www.twitch.tv/zfg1 has username zfg1).
-t, --videotype (Default: All) The type of videos to download. Can be: All, Upload, Archive, or Highlight.
--help Display this help screen.
--version Display version information.
And if you run dotnet TwitchChatDownloader.dll video
, you'll get this help:
ERROR(S):
Required option 'v, videoid' is missing.
-v, --videoid Required. The video ID (for example, https://www.twitch.tv/videos/213105685 has ID 213105685). This
will download subtitles for a single video.
--help Display this help screen.
--version Display version information.
Hopefully this is self-explanatory, but if not, below are some examples.
Downloading for a single video (https://www.twitch.tv/videos/69027652)
dotnet TwitchChatDownloader.dll video --videoid 69027652
Example log output:
[12:51:59 INF] Getting info for video ID: 69027652
[12:51:59 INF] Got info for video "Double 46"
[12:51:59 INF] Saving video Double 46.
[12:51:59 INF] Getting comments for video Double 46, ID 69027652.
[12:52:00 INF] Got 149 comments for video.
[12:52:00 INF] Wrote SRT file to C:\Users\Peter\Desktop\TwitchChatDownloader\SRT\Double 46-v69027652.srt.
[12:52:00 INF] Done saving video chat.
In this case, it saved off a single SRT file (Double 46-v69027652.srt
) containing the comments as subtitles.
Downloading only highlights from a user's channel (https://www.twitch.tv/zfg1)
dotnet TwitchChatDownloader.dll user --username zfg1 --videotype highlight
This will download a bunch of SRT files (for each highlight-type video).
The appsettings.json
contains configuration settings that you can edit, such as:
SrtFileSettings:OutputDirectoryPath
: This is where SRT files are saved.SrtSettings
has a few options:MaxMessagesOnscreen
: Puts an upper bound on how many comments are visible at any time. Useful for very chatty streams, so that your video doesn't get obscured by a wall of text.MaxSecondsOnscreen
: Upper bound on long a message can be visible. Messages may be visible less than this time if messages are coming in quickly, sinceMaxMessagesOnscreen
will "bump off" older messages with newer ones.DeltaMilliseconds
: When an newer message "bumps off" an older message, the older message will disappear a few milliseconds before the newer one appears. This controls that timing. This may be useful for video players where having zero spacing between messages (the default behavior) causes them to "climb up the screen".
CommentsCacheSettings:CacheDirectoryPath
: This app reaches out to Twitch's API to get comments for a video. Comments for videos are cached on disk, so that subsequent runs for the same video don't have to reach out over the network again, speeding up subsequent runs. This is useful if you've tweaked someSrtSettings
, and want to rerun a download and not have to wait as long.Serilog:WriteTo
: Contains Serilog settings such as the file log path, and verbosity levels. May be useful for debugging purposes.TwitchSettings:ClientId
: You can get a different Client ID by registering an application at Twitch. I've included a valid one, so you shouldn't have to change this, unless it gets revoked due to abuse.
If you want to improve something (fix a bug, or add an enhancement), then file a pull request. Once CI checks pass, it's reviewed, and merged, a new release will automatically be published.
If you don't know how to implement the improvement, then file an issue and describe what you'd like to see improved. Hopefully someone will implement it!