Skip to main content

Python bytecode decompiler for Python 1.0 through 3.15 (Python port of depyo.js)

Project description

depyo

Python bytecode decompiler for Python 1.0 through 3.15.

This is the Python port of depyo.js. The JavaScript version is the canonical implementation and is ~4–5× faster; this port exists so you can hack on decompilation logic in Python without a Node runtime.

Status

  • Fixture parity with JS baseline: 1183 / 1216 byte-identical (97.3%) across the full fixture suite (Python 1.0–3.15).
  • Port-only bugs: 0. The 33 remaining diverging fixtures fail identically on the JS side — they're shared bug-for-bug parity, not port defects.
  • Bytecode coverage: Python 1.0 through 3.15.

Install

pip install depyo

Or from source:

pip install -e .

Usage

depyo my_script.pyc
# → writes my_script.py next to the input

All JS CLI flags are supported (--asm, --debug, --raw, --dump, --stats, --strict, --py-version, --basedir, --out, --skip-source-gen, --skip-path, --marshal, --marshal-scan, --file-ext). Run depyo --help for the full list.

Speed

Measured across 1216 .pyc fixtures, 10 passes each:

Runtime ms/file pyc/s Relative
Node.js (V8) — depyo.js 0.47 2143 1.0×
CPython 3.12 2.48 402 5.3× slower
PyPy 3.10 3.87 259 8.3× slower

This port is ~4–5× slower than the JS original. Honest disclosure: if you need throughput, use the JS version. If you want to read and modify decompilation logic in idiomatic Python, use this one.

PyPy does not help — it's actually 35% slower than CPython on this workload. The fixtures are short-lived (fresh PycReader/PycDecompiler per file), so the JIT never warms up; hot paths are also heavy on hasattr/getattr/isinstance against polymorphic shapes, which PyPy doesn't specialize well.

Scope

Decompiles .pyc / .pyo from Python 1.0 through 3.15, including:

  • All control flow (if/elif/else, while, for, try/except/finally, with, match/case)
  • Comprehensions (list, set, dict, generator, async)
  • Functions, classes, decorators, async def, coroutines
  • PEP 695/696 generic type syntax (3.12+)
  • PEP 750 template strings (3.14+)

License

MIT — see LICENSE.

Copyright (c) 2011–2026 Sergey Kuznetsov.

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

depyo-0.2.0.tar.gz (173.3 kB view details)

Uploaded Source

Built Distribution

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

depyo-0.2.0-py3-none-any.whl (229.3 kB view details)

Uploaded Python 3

File details

Details for the file depyo-0.2.0.tar.gz.

File metadata

  • Download URL: depyo-0.2.0.tar.gz
  • Upload date:
  • Size: 173.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.2

File hashes

Hashes for depyo-0.2.0.tar.gz
Algorithm Hash digest
SHA256 eec175933d711ed5bd2859b1aedc86f98789b4dbfd35c18486115373e57b48dd
MD5 12ec871534302f9afdefb08a43a4f044
BLAKE2b-256 2932f9e7c677bb748ba01d5c9705a3f3170e7a92af2607e5b983d94a157a1921

See more details on using hashes here.

File details

Details for the file depyo-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: depyo-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 229.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.2

File hashes

Hashes for depyo-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 eb268f89750b35157c202bc6d5dc88c59d2810cdebc9f0a8e5b274fa77094647
MD5 c2ae13d2c6b0308858a57131e9020508
BLAKE2b-256 eb472fbd9c6becd2b4306655681760f0fda79d43647ebe869c6740a062fa3498

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