Skip to main content

A python interface for FFmpeg using asyncio

Project description

python-ffmpeg

A python interface for FFmpeg using asyncio

Requirements

  • Python 3.7+
  • pyee

Installation

pip install python-ffmpeg

Usage

import asyncio

from ffmpeg import FFmpeg


async def main():
    ffmpeg = (
        FFmpeg()
        .option("y")
        .input(
            "rtsp://example.com/cam",
            # Specify file options using kwargs
            rtsp_transport="tcp",
            rtsp_flags="prefer_tcp",
        )
        .output(
            "output.ts",
            # Use a dictionary when an option name contains special characters
            {"codec:v": "copy"},
            f="mpegts",
        )
    )

    @ffmpeg.on("start")
    def on_start(arguments):
        print("Arguments:", arguments)

    @ffmpeg.on("stderr")
    def on_stderr(line):
        print("stderr:", line)

    @ffmpeg.on("progress")
    def on_progress(progress):
        print(progress)

    @ffmpeg.on("progress")
    def time_to_terminate(progress):
        # Gracefully terminate when more than 200 frames are processed
        if progress.frame > 200:
            ffmpeg.terminate()

    @ffmpeg.on("completed")
    def on_completed():
        print("Completed")

    @ffmpeg.on("terminated")
    def on_terminated():
        print("Terminated")

    @ffmpeg.on("error")
    def on_error(code):
        print("Error:", code)

    await ffmpeg.execute()


if __name__ == "__main__":
    asyncio.run(main())

API

FFmpeg

init(executable='ffmpeg')

  • executable: the path to the ffmpeg executable

Initializes the FFmpeg instance.

option(key, value=None)

  • key
  • value

Specifies a global option -key or -key value

input(url, options=None, **kwargs)

  • url
  • options
  • kwargs

Specifies an input file. An arbitrary number of input files can be specified by calling this method multiple times.

output(url, options=None, **kwargs)

  • url
  • options
  • kwargs

Specifies an output file. An arbitrary number of output files can be specified by calling this method multiple times.

execute()

Executes FFmpeg using specified options and files.

terminate()

Gracefully terminates the running FFmpeg process.

on(event, listener=None)

  • event: the name of the event
  • listener: the callback function

Registers the listener to the event. This method can be used as a decorator.

Event: 'start'

  • arguments: a sequence of arguments to execute FFmpeg

The 'start' event is emitted just before FFmpeg is executed.

Event: 'stderr'

  • line

The 'stderr' event is emitted when FFmpeg writes a line to stderr.

Event: 'progress'

  • progress: a namedtuple with frame, fps, size, time, bitrate, speed fields

The 'progress' event is emitted when FFmpeg reports progress.

Event: 'completed'

The 'completed' event is emitted when FFmpeg is successfully exited.

Event: 'terminated'

The 'terminated' event is emitted when FFmpeg is terminated by calling FFmpeg.terminate().

Event: 'error'

  • code: a return code of the FFmpeg process

The 'error' event is emitted when FFmpeg is exited with a non-zero return code

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

python-ffmpeg-1.0.16.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

python_ffmpeg-1.0.16-py3-none-any.whl (6.2 kB view details)

Uploaded Python 3

File details

Details for the file python-ffmpeg-1.0.16.tar.gz.

File metadata

  • Download URL: python-ffmpeg-1.0.16.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for python-ffmpeg-1.0.16.tar.gz
Algorithm Hash digest
SHA256 c6ca40a0b8e807b4a65384cf2d4e920b25a93f19c8f2f3d127e6d3449e236631
MD5 85dbd3d42d866e69d9120d784fa09fef
BLAKE2b-256 bb647643c72064919125d1474ac96fa0a49746e944ca9832a193caade283f029

See more details on using hashes here.

File details

Details for the file python_ffmpeg-1.0.16-py3-none-any.whl.

File metadata

File hashes

Hashes for python_ffmpeg-1.0.16-py3-none-any.whl
Algorithm Hash digest
SHA256 466165ed39ecf461d8d7c201fc46e6ab1c44c7a9bb35466740c6d834f694f8e4
MD5 a7925cc1199c3965a8ef1ecc0a406615
BLAKE2b-256 e569ec902a2d4ba07c4245b0eeddda52dcd1859799a7c6d6b6dc861733ccc025

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