Skip to main content

Download images and videos from Instagram

Project description

BasketCase

Download images and videos from Instagram.

Notable features:

  • Stories can be downloaded without triggering the "seen" flag.
  • Downloads a high quality version of a profile picture.

https://www.youtube.com/watch?v=NUTGr5t3MoY ;)

Installation

Install it from PyPI as a user install.

pip install --user basketcase

This should put the executable basketcase on your PATH.

Alternatively, you could install it in a virtual environment. I keep mine at ~/venv, and I have a shell alias to quickly activate it.

Also, a pre-built executable for Linux is provided with the releases.

Command-line usage

basketcase -u "https://instagram.com/p/<post_id>"

Downloaded resources will be stored in the current working directory (i.e. $PWD/basketcase_downloads).

To download from multiple URLs, create a text file (e.g. urls.txt) and populate it with resource URLs:

https://instagram.com/p/<post_id>
https://instagram.com/reel/<reel_id>
https://instagram.com/<username>
basketcase -f ./urls.txt

See --help for more info.

Supported URLs

Supported URL Description
https://instagram.com/<username> User profile. Downloads stories from the past 24 hours, and the profile picture.
https://instagram.com/p/<post_id> Standard publication.
https://instagram.com/reel/<reel_id> Reels movie
https://www.instagram.com/stories/highlights/<highlight_id>/ A collection of stories, or "highlights"
https://www.instagram.com/s/<random_characters> A shorter type of URL

Authentication

  1. Add a session cookie
basketcase --cookie <session_cookie_id> --cookie-name "my session"
# Added session id: 1
  1. Specify its identifier when downloading
basketcase -s 1

List all available sessions with basketcase -l. To disable sessions, use --no-session. If only one exists, it is treated as the default.

User data

Cookies and other application data are kept in your home directory (i.e. ~/.basketcase).

Development setup

See Packaging Python Projects.

  1. cd to the project root and create a virtual environment in a directory named venv, which is conveniently ignored in version control.
  2. Install the dependencies.
pip install -r requirements.txt
  1. Install this package in editable mode.
pip install -e .

Package build and upload

  1. Update the requirements list.
pip freeze --exclude-editable > requirements.txt
  1. Increment the version on pyproject.toml.
  2. Build the package.
python -m build
  1. Commit and push the changes (and a new version tag) to the git repository.
  2. Publish it.
python -m twine upload dist/*

Build an executable

With the zipapp module we can build the whole package as an executable file for Linux. The only runtime requirement is Python 3.

  1. cd to the project root.
  2. Activate the virtual environment.
  3. Run sh zipapp.sh.

The executable file basketcase is in the dist folder.

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

basketcase-7.0.1.tar.gz (46.7 kB view details)

Uploaded Source

Built Distribution

basketcase-7.0.1-py3-none-any.whl (35.1 kB view details)

Uploaded Python 3

File details

Details for the file basketcase-7.0.1.tar.gz.

File metadata

  • Download URL: basketcase-7.0.1.tar.gz
  • Upload date:
  • Size: 46.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for basketcase-7.0.1.tar.gz
Algorithm Hash digest
SHA256 d8fc5ee3c2badd6edeed9484c058c38ad61b54cb6910f0c89b9eeb0bb5800cd3
MD5 0edd176d695f8a03221609c538237e5a
BLAKE2b-256 f0a26ab5e4b4900e79730100deff095e54de56224a0ec9bcc0a4170de1ea1b13

See more details on using hashes here.

File details

Details for the file basketcase-7.0.1-py3-none-any.whl.

File metadata

  • Download URL: basketcase-7.0.1-py3-none-any.whl
  • Upload date:
  • Size: 35.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for basketcase-7.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9f1af695b7966a3cc7bd5f769af7844d0a6afe2fc0c83012412d8066f06cc767
MD5 b8b064b247f3eb48efc2050c8fd669b8
BLAKE2b-256 7d3d22a4961ccf3a7e6dec528c4e9a49e5108dd8b6cf890ea0f95cf839b6307d

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