Skip to main content

Steam client library for Python

Project description

Steam Client

A Python library for interacting with a locally installed Steam client — enumerate your game library/non-steam games, read game metadata and artwork paths, and send Steam URI commands.

Docs

Buy Me a Coffee Ko-fi


Installation

Requires Python 3.8+.

pip install steam-client

Or install from source:

pip install -e .

Quickstart

from steam_client.steam import Steam

steam = Steam()  # Uses default path: C:\Program Files (x86)\Steam

# On Windows, auto-detect path from registry:
from steam_client.utils import steam_from_registry
steam = steam_from_registry()

Common Operations

List all installed games

for game in steam.library.games():
    print(game.appid, game.name)

Find a game

game = steam.library.game_by_id("440")       # by app ID
game = steam.library.game_by_name("Portal 2") # by name (case-insensitive)

Artwork paths

game.header   # Path to header image    (460×215 jpg)
game.grid     # Path to grid image      (600×900 jpg)
game.hero     # Path to hero image
game.icon     # Path to icon file, or None

Launch and manage games via Steam URI commands

from steam_client.commands import Commands, SteamWindows

commands = Commands()
commands.run_game_id("440")         # Launch a game
commands.store("440")               # Open store page
commands.install("440")             # Prompt install
commands.uninstall("440")           # Prompt uninstall
commands.open(SteamWindows.FRIENDS) # Open a Steam window
commands.open_url("https://store.steampowered.com")

Or launch a game directly from a SteamGame object:

game.run()

Users and shortcuts

for user in steam.users:
    print(user.user.data.PersonaName)

for shortcut in steam.library.shortcuts():
    print(shortcut.appname)

Platform Notes

Platform Default path Registry helper
Windows C:\Program Files (x86)\Steam steam_from_registry()
Linux ~/.local/share/steam Not available

Pass a custom path to override the default:

steam = Steam("/custom/steam/path")

Requires read access to local Steam config files (libraryfolders.vdf, shortcuts.vdf, appmanifest files).


Development

pytest          # Run tests
flake8 steam_client  # Lint
mypy steam_client    # Type check
mkdocs serve         # Preview docs locally
mkdocs build --strict # Validate docs build
tox             # Run all environments (lint, type, docs, py311–314)

bump-my-version show current_version   # Show current version
bump-my-version bump patch             # 4.0.0 → 4.0.1
bump-my-version bump minor             # 4.0.0 → 4.1.0
bump-my-version bump major             # 4.0.0 → 5.0.0

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

steam_client-4.1.0.tar.gz (13.7 kB view details)

Uploaded Source

Built Distribution

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

steam_client-4.1.0-py3-none-any.whl (10.9 kB view details)

Uploaded Python 3

File details

Details for the file steam_client-4.1.0.tar.gz.

File metadata

  • Download URL: steam_client-4.1.0.tar.gz
  • Upload date:
  • Size: 13.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for steam_client-4.1.0.tar.gz
Algorithm Hash digest
SHA256 27375137911d8031f70ccfca88368e7587cb462bc5b739b07fa804e5875cbd19
MD5 7e06323bfaf690c51d66895531076599
BLAKE2b-256 246a8edcabe4b371f424e14b996b7e05ac541287f48e83c1754bd48ff766ee4b

See more details on using hashes here.

Provenance

The following attestation bundles were made for steam_client-4.1.0.tar.gz:

Publisher: pypi.yaml on Garulf/Steam-Client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file steam_client-4.1.0-py3-none-any.whl.

File metadata

  • Download URL: steam_client-4.1.0-py3-none-any.whl
  • Upload date:
  • Size: 10.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for steam_client-4.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f220c27189c52bdabb238430c1ba551d474fabff16b6b1c3159698d6e07d5584
MD5 16c042077a9fe2a5ab996a1c5e658b3d
BLAKE2b-256 c339fa3e2bbfa698f2d967b82f30aa0cbb9d487d11a5b137b9a0c0c14c8d99ac

See more details on using hashes here.

Provenance

The following attestation bundles were made for steam_client-4.1.0-py3-none-any.whl:

Publisher: pypi.yaml on Garulf/Steam-Client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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