Python script to download Instagram livestreams and replays.
|
7 år sedan | |
---|---|---|
.github | 7 år sedan | |
pyinstalive | 7 år sedan | |
.gitignore | 7 år sedan | |
FAQ.md | 7 år sedan | |
LICENSE | 8 år sedan | |
MOREHELP.md | 7 år sedan | |
README.md | 7 år sedan | |
setup.py | 7 år sedan |
This script enables you to download any ongoing Instagram livestreams as well as any available replays. It is based on another script that has now been discontinued.
pyinstalive -c
to generate a configuration file.pyinstalive -r "<live-username>"
to start downloading a livestream or replay.You need ffmpeg, Git and Python 2.7.x or 3.5>= with pip and setuptools installed before you can install and use this script. Make sure all tools are accessible via command line (added to your PATH if on Windows, use Google).
Run the following command in Command Prompt (might need to be run as administrator on Windows) or a terminal:
pip install git+https://github.com/notcammy/PyInstaLive.git@2.5.0 --process-dependency-links
To update PyInstaLive to the latest version (currently 2.5.0) run the following command:
pip install git+https://github.com/notcammy/PyInstaLive.git@2.5.0 --process-dependency-links --upgrade
If you want to install a specific version of PyInstaLive when for example the newest version contains a bug, you can specify the version tag in the install command:
pip install git+https://github.com/notcammy/PyInstaLive.git@2.2.0 --process-dependency-links
Use the version number you want after the @ symbol (e.g 2.2.0).
Make sure there is a configuration file called pyinstalive.ini
in the directory you want to run PyInstaLive from.
You can run pyinstalive -c
to automatically generate a default configuration file if one is not present.
For more information about the configuration file go here.
Here is an example of a valid configuration file:
[pyinstalive]
username = johndoe
password = grapefruits
save_path =
show_cookie_expiry = true
clear_temp_files = false
save_replays = true
run_at_start =
run_at_finish =
save_comments = false
[ftp]
ftp_enabled = false
ftp_host =
ftp_save_path =
ftp_username =
ftp_password =
Use the following command to run PyInstaLive:
pyinstalive -u "<username>" -p "<password>" -r "<live-username>"
Where <username>
is your account's username, <password>
is your password and <live-username>
is the username of the user whose livestream or replay you want to download.
pyinstalive -u "johndoe" -p "grapefruits" -r "janedoe"
Or (see notes)
pyinstalive -r "janedoe"
Below is an example of PyInstaLive's output after downloading a livestream:
----------------------------------------------------------------------
PYINSTALIVE (SCRIPT V2.5.0 - PYTHON V3.6.3) - 06:45:30 PM
----------------------------------------------------------------------
[I] Logging in to user "johndoe" successful.
[I] Login cookie expiry date: 2018-01-31 at 10:30:00 PM
[I] Checking user "janedoe"...
----------------------------------------------------------------------
[I] Checking for ongoing livestreams...
[I] Livestream downloading started...
----------------------------------------------------------------------
[I] Username : janedoe
[I] Viewers : 100 watching
[I] Airing time : 2 minutes And 10 seconds
[I] Status : Active
[I] MPD URL : https://scontent-amt2-1.cdninstagram.com/hvideo-prn1/v/rID1yGvO_UPlsukIhbhOx/live-dash/dash-hd/17907800311113848.mpd?_nc_rl=AfBVd51QpQOj_ImC&oh=aa8d53b4fd736c0edc29c97b411bd32b&oe=5A6FDE8B
----------------------------------------------------------------------
[I] Downloading livestream... press [CTRL+C] to abort.
----------------------------------------------------------------------
[I] The livestream has ended.
[I] Time recorded : 13 minutes and 10 seconds
[I] Stream duration : 15 minutes and 20 seconds
[I] Missing (approx.) : 2 minutes and 10 seconds
----------------------------------------------------------------------
[I] Stopping comment downloading and saving comments (if any)...
[I] Successfully saved 550 comments to logfile.
----------------------------------------------------------------------
[I] Stitching downloaded files into video...
[I] Successfully stitched downloaded files into video.
----------------------------------------------------------------------
Python 2 cannot save most unicode characters in comments such as emojis if it's not built from source using the --enable-unicode=ucs4
flag. Read more about this here. This should probably not affect pre-installed Python 2 installations on Linux systems.
The username
and password
arguments are not required when you have specified these in the configuration file.
This script is also reported to work on Python 3.4.x but is not officially supported.
If the script is ran and there are available replays as well as an ongoing Instagram livestream, only the livestream will be downloaded. Run the script again after the livestream has ended to download the available replays.
You can find a list of frequently asked questions here.
You can find a list of available commands and an explanation of the configuration file here.
If you would like to report a bug or ask a question please open an issue.