Skip to main content

a cli program to download video at m3u8 url

Project description

m3u8downloader is a tool to download video at a m3u8 link. HTTP Live Streaming (HLS) is becoming popular. m3u8 playlist is used by HLS to serve video fragments of different quality to different clients. This tool supports HLS master playlist and media playlist. If master playlist is given, it selects the highest resolution automatically. HLS fragment encryption is supported. Resume from partial download is supported, just rerun the same command to continue.

ffmpeg is used to convert the downloaded fragments into final mp4 video file.

Installation

To install m3u8downloader, simply:

$ sudo apt install -y ffmpeg pipx
$ pipx install m3u8downloader

Quick Start

Example command line usage:

downloadm3u8 -o ~/Downloads/foo.mp4 https://example.com/path/to/foo.m3u8

If ~/.local/bin is not in $PATH, you can use full path:

~/.local/bin/downloadm3u8 -o ~/Downloads/foo.mp4 https://example.com/path/to/foo.m3u8

Here is built-in command line help:

usage: m3u8downloader [-h] [--user-agent USER_AGENT] [--origin ORIGIN] [--version]
                      [--debug] --output OUTPUT [--tempdir TEMPDIR] [--keep]
                      [--concurrency N]
                      URL

download video at m3u8 url

positional arguments:
  URL                   the m3u8 url

optional arguments:
  -h, --help            show this help message and exit
  --user-agent USER_AGENT
                        specify User-Agent header for HTTP requests
  --origin ORIGIN       specify Origin header for HTTP requests
  --version             show program's version number and exit
  --debug               enable debug log
  --output OUTPUT, -o OUTPUT
                        output video filename, e.g. ~/Downloads/foo.mp4
  --tempdir TEMPDIR     temp dir, used to store .ts files before combing them into mp4
  --keep                keep files in tempdir after converting to mp4
  --concurrency N, -c N
                        number of fragments to download at a time

Documentation

Config File Support

You may use a config file to specify some command line arguments.

  • supported config files, later takes precedence:

    • /etc/m3u8downloader.conf

    • /etc/m3u8downloader/m3u8downloader.conf

    • ~/.config/m3u8downloader.conf

    • ~/.config/m3u8downloader/m3u8downloader.conf

  • config file format

    # comments and empty lines are ignored.
    KEY=VALUE
    # or
    KEY="VALUE"
    # boolean values may be true|false|yes|no|1|0
  • supported keys:

    user_agent=<string>
    origin=<string>
    tempdir=<string>
    concurrency=<int>
    debug=<true|false>

    Their meaning is the same as their counterpart in command line arguments.

  • if a config is specified both in config file and command line arguments, command line arguments will take precedence.

Limitations

This tool only parses minimum m3u8 extensions for selecting media playlist from master playlist, downloading key and fragments from media playlist. If a m3u8 file doesn’t download correctly, it’s probably some new extension was added to the HLS spec which this tool isn’t aware of.

Bug Report

Bugs should be reported to github issues.

ChangeLog

  • v0.11.1

    • add –keep option to keep temp files after converting to mp4

    • bugfix: when on windows, properly delete temp dir when filename contains special characters.

  • v0.10.1

    • lifted lib version restriction

  • v0.10.0

    • add support for config file

    • handle Ctrl+C and SIGTERM properly

  • v0.9.0

    • add support for –user-agent and –origin parameters

  • v0.8.7

    • bugfix: do not rewrite KEY URI if it is already a local file path.

  • v0.8.6

    • fix a regression in v0.8.4. the v0.8.4 release should be avoided. Either use v0.8.3 or v0.8.6+

  • v0.8.4

    • minor bugfix: still try rewrite path when using m3u8 file from cache. when rewrite path in m3u8 file, do not rewrite if path has already been rewritten before. This is a minor change, it only fix things when process is killed when .m3u8 file is downloaded but path in it has not been rewritten yet.

  • v0.8.3

    • bugfix: ensure output file name and temp dir name is always valid for windows platform.

  • v0.8.1

    • bugfix: should rewrite key uri to local file path.

    • some bugfix for windows platform.

  • v0.8.0 2019-03-31

    • add logrotate for log handler

  • v0.7.8 2019-03-09

    • bugfix: fragment url rewrite fail for some cases

  • v0.7.7 2019-03-08

    • bugfix: always rewrite fragment url to local abs path

  • v0.7.5 2019-03-07

    • set default log level to INFO

  • v0.7.4 2019-03-07

    • initial release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

m3u8downloader-0.11.1.tar.gz (12.7 kB view details)

Uploaded Source

Built Distribution

m3u8downloader-0.11.1-py2.py3-none-any.whl (13.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file m3u8downloader-0.11.1.tar.gz.

File metadata

  • Download URL: m3u8downloader-0.11.1.tar.gz
  • Upload date:
  • Size: 12.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.2

File hashes

Hashes for m3u8downloader-0.11.1.tar.gz
Algorithm Hash digest
SHA256 d0bac572467021a0ec7a220f478ccd2ad0aa98f426bbe7d479b7828525747c1e
MD5 fda7bfb2c689bd85c2f653f915dac90e
BLAKE2b-256 bc1b3becb9de36f20be6ec479a13f6d30ba0c129c112f2d68f8b4a03a46f00ab

See more details on using hashes here.

File details

Details for the file m3u8downloader-0.11.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for m3u8downloader-0.11.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 99ccf114effafa1cdafa8b4a045e42be738b9f629623ec66e7922e43c23d53e3
MD5 abaae48eb369a8dd6e4e4b1bb3386012
BLAKE2b-256 6829fadec2efc435bc890a21ba7b90bbff83325a8e45e32324fe17987c0e332e

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page