Skip to main content

itch.io bulk game downloader

Project description

itch-dl

PyPI

Bulk download games from itch.io

[!WARNING] This tool does not let you download paid games for free. To download paid games, you must have them attached in your library.

How to use

  • Log into itch.io with the account you'd like to use for downloading.
  • Generate a new API key on your user account page.
  • Optional: Save the API key in the itch-dl configuration file.
  • Run the downloader: uvx itch-dl https://itch.io/jam/yourjamhere
    • Add --api-key <KEY> if you did not save the API key to the config file.
  • Wait. This is going to take a while.

More arguments are available - check them out with itch-dl --help.

The downloader is able to grab more or less everything you can download via the itch app.

The input URL can be one of the supported link formats listed above, a path to a itch.io JSON file with game jam entries, a list of itch.io game URLs (not browse/jam pages!) to download.

It's expected that the downloader output will not be complete - logs are stupidly verbose and it prints a report on failed downloads and external URLs (links to files that are not on itch.io itself, but rather on an external host like Google Drive, Dropbox, etc), so you must manually grab whatever was not handled for you automatically.

The downloader also grabs the entry page HTML, which usually comes with controls and such. By default, it does not download images, assets and so on, just the text - use --mirror-web to try and download these as well. This does not work very well yet, but gets the basics done.

Game Jam Entries JSON

Downloader can parse and download games from a game jam entries JSON file if you need it. (The script basically automates the steps below, so if it's not able to do the same, please create an issue!)

  • Go to your jam's page, ex. https://itch.io/jam/gbcompo21 and right-click -> View Source.
  • Ctrl-F for "id": - it should find that text once, followed by a number. Write it down.
  • (It you found it multiple times, grab the one after I.ViewJam something something.)
  • Download https://itch.io/jam/ID/entries.json (replacing ID with what you wrote down).
  • Feed that to itch-dl!

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

itch_dl-0.6.1.tar.gz (17.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

itch_dl-0.6.1-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

Details for the file itch_dl-0.6.1.tar.gz.

File metadata

  • Download URL: itch_dl-0.6.1.tar.gz
  • Upload date:
  • Size: 17.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.12

File hashes

Hashes for itch_dl-0.6.1.tar.gz
Algorithm Hash digest
SHA256 ec209598ffa9a0d71260c4d0c98f04009a0cc829dc15f0a139e93758b6695fb2
MD5 5d760333187965ff26e3562d071eb776
BLAKE2b-256 2b48148769a2c7245a0e9b7d699171e3280777fd1b0fcd86396ca18883ebf33d

See more details on using hashes here.

File details

Details for the file itch_dl-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: itch_dl-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 21.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.12

File hashes

Hashes for itch_dl-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 13ede3ba4b72b52dee21cca1df5509e1b45406556ea9648fdeb8568ceccaa89c
MD5 fb141aec2f20078fbc1277957ddeb17f
BLAKE2b-256 8e78ed6c0e00f847086d6b4e3a689778ad42b2ffcdae0286d19090e77d2a653a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page