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.2.tar.gz (46.8 kB view details)

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for basketcase-7.0.2.tar.gz
Algorithm Hash digest
SHA256 9c12740e2206f962e9ba0bb7e7866c4f7a3791eff8be7952c22a9cae7c3838a9
MD5 2f10554a62078c1ba104001422ae9672
BLAKE2b-256 7539a95c8e6199bcfa24ec1bd8be9817f80c6e4a50142826fbe37137856fd23c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: basketcase-7.0.2-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.11.2

File hashes

Hashes for basketcase-7.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 dc2d76f1ca3af752b4b7761b273c86da6c01bdfed4752e6d2294ede4c8bfe7c1
MD5 d2651346cad4b618ef4360533bcc9f98
BLAKE2b-256 90b587972134d3a8e340b152d10bceda1f4c56a5a00af43d26c138f33aaf3986

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