Skip to main content

Easy streaming using FFmpeg to YouTube Live, Periscope, Facebook Live, Twitch, ...

Project description

https://travis-ci.org/scivision/PyLivestream.svg?branch=master https://coveralls.io/repos/github/scivision/PyLivestream/badge.svg?branch=master https://ci.appveyor.com/api/projects/status/uwhsko29b1g5c3no?svg=true Python versions (PyPI) Distribution format (PyPI) Maintainability

Python scripted livestreaming using FFmpeg

Streams to one or multiple streaming sites simultaneously. FFmpeg is used from Python subprocess to stream to Facebook Live, YouTube Live, Periscope, Twitch, Mixer, Ustream, Vimeo and more for streaming broadcasts. The Python scripts compute good streaming parameters, and emit the command used so you can just copy and paste in the future if you wish. Works on any OS (Mac, Linux, Windows) and computing platform, including PC, Mac, and Raspberry Pi. Uses an .ini file to adjust all parameters.

PyLivestream diagram showing screen capture or webcam simultaneously livestreaming to multiple services.
FFmpeg:

>= 3.0 required

Python:

>= 3.6 required

Install

Latest release:

python -m pip install PyLivestream

Development version:

git clone https://github.com/scivision/PyLivestream

cd PyLivestream

python -m pip install -e .

Configuration

You can skip past this section to “stream start” if it’s confusing. The defaults might work to get you started.

The stream.ini file contains parameters relevant to your stream. The [DEFAULT] section has parameters that can be overridden for each site, if desired.

  • screencap_origin: origin (upper left corner) of screen capture region in pixels.

  • screencap_res: resolution of screen capture (area to capture, starting from origin)

  • screencap_fps: frames/sec of screen capture

  • webcam_res: webcam resolution – find from v4l2-ctl --list-formats-ext or webcam spec sheet.

  • webcam_fps: webcam fps – found from command above or webcam spec sheet

  • audiofs: audio sampling frequency. Typically 44100 Hz (CD quality).

  • audio_bps: audio data rate–leave blank if you want no audio (usually used for “file”, to make an animated GIF in post-processing)

  • preset: veryfast or ultrafast if CPU not able to keep up.

Next are sys.platform specific parameters. Find webcam name by:

  • Windows: ffmpeg -list_devices true -f dshow -i dummy

  • Mac: ffmpeg -f avfoundation -list_devices true -i ""

  • Linux: v4l2-ctl --list-devices

Seek help in FFmpeg documentation, try capturing to a file first and then update stream.ini for your sys.platform.

  • exe: override path to desired FFmpeg executable. In case you have multiple FFmpeg versions installed (say, from Anaconda Python).

Finally are the per-site parameters. The only thing you would possibly need to change here is the server for best performance for your geographic region. The included stream.ini is with default servers for the Northeastern USA.

Stream Start

The program will load a *.key file according to the configuration file key for the website. For example, Periscope expects to see the stream hexadecimal key in periscope.key, as obtained from the app. Likewise, YouTube expects a file youtube.key with the hexadecimal stream key and so on.

YouTube Live

  1. configure YouTube Live.

  2. Edit file youtube.key to have the YouTube hexadecimal stream key

  3. Run Python script and chosen input will stream on YouTube Live.

python ScreenshareLivestream.py youtube

Facebook Live

  1. configure your Facebook Live stream

  2. Put stream ID from https://www.facebook.com/live/create into the file facebook.key

  3. Run Python script for Facebook with chosen input

python ScreenshareLivestream.py facebook

Periscope

  1. create a new stream by EITHER:

    • from phone Periscope app, go to Profile -> Settings -> Periscope Producer and see your Stream Key. The “checking source” button will go to “preview stream” once you do step #2.

    • from computer web browser, go to https://www.periscope.tv/account/producer and Create New Source.

  2. Put the hexadecimal stream key into periscope.key

  3. Run Python script for Periscope with chosen input

python ScreenshareLivestream.py periscope

I prefer using the Phone method as then the phone is a “second screen” where I can see if the stream is lagging, and if I “leave broadcast” and come back in, I can comment from my phone etc.

Twitch

  1. create stream from Twitch Dashboard. If you are not in the Northeast US, edit stream.ini to have the closest server.

  2. put Twitch stream key into file twitch.key

  3. Run Python script for Twitch with chosen input

python ScreenshareLivestream.py twitch

Usage

Due to the complexity of streaming and the non-specific error codes FFmpeg emits, the default behavior is that if FFmpeg detects one stream has failed, ALL streams will stop streaming and the program ends.

  • stream.ini is setup for your computer and desired parameters

  • site is facebook, periscope, youtube, etc.

  • For Webcam.py and Screenshare.py, more than one site can be specified for simultaneous multi-streaming

  • remember to setup a *.key file with the hexadecimal stream key for EACH site first, OR input the stream key into the “key:” field of your *.ini file.

Webcam

Audio is included:

python WebcamLivestream.py site(s)

Stream to multiple sites, in this example Periscope and YouTube Live simultaneously:

python WebcamLivestream.py youtube periscope

Screen Share Livestream

Audio is included:

python ScreenshareLivestream.py site(s)

Stream to multiple sites, in this example Periscope and YouTube Live simultaneously:

python ScreenshareLivestream.py youtube periscope

File Input

Loop single video endlessly
python FileLoopLivestream.py site videofile
several video files

Glob list of video files to stream:

python FileGlobLivestream.py site path pattern
-loop

optionally loop endlessly the globbed file list

-image

if you have AUDIO files, you should normally set an image to display, as most/all streaming sites REQUIRE a video feed–even a static image.

stream all videos in directory

Example: all AVI videos in directory ~/Videos:

python FileGlobLivestream.py youtube ~/Videos "*.avi"
stream endlessly looping videos

Example: all AVI videos in ~/Videos are endlessly looped:

python FileGlobLivestream.py youtube ~/Videos "*.avi" -loop
stream all audio files in directory

Glob list of video files to stream. Must include a static image (could be your logo):

python FileGlobLivestream.py site path pattern -image image

path path to where video files are pattern e.g. *.avi pattern matching video files -image filename of image to use as stream background (REQUIRED for most websites)

Example: stream all .mp3 audio under ~/Library directory:

python FileGlobLivestream.py youtube ~/Library "*.mp3" -image mylogo.jpg

Screen capture to disk

This script saves your screen capture to a file on your disk:

python ScreenCapture2disk.py myvid.avi

Utilities

  • PyLivestream.get_framerate(vidfn) gives the frames/sec of a video file.

  • PyLivestream.get_resolution(vidfn) gives the resolution (widthxheight) of video file.

Notes

  • Linux requires X11, not Wayland (choose at login)

  • x11grab was deprecated in FFmpeg 3.3, was previously replaced by xcbgrab

  • Reference webpage

  • Test videos for looping/globbing

FFmpeg References

Windows

DirectShow didn’t work for me on Windows 10, so I used gdigrab instead.

Stream References

Logo Credits

  • Owl PC: Creative Commons no attrib. commercial

  • YouTube: YouTube Brand Resources

  • Facebook: Wikimedia Commons

  • Periscope

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

PyLivestream-1.6.3.tar.gz (230.8 kB view hashes)

Uploaded Source

Built Distribution

PyLivestream-1.6.3-py3-none-any.whl (20.4 kB view hashes)

Uploaded Python 3

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