Skip to main content

Python redistribution of Deno binaries

Project description

Deno for Python

PyPI version PyPI downloads License

The easiest way to install and use Deno — the modern JavaScript and TypeScript runtime — in your Python projects.

What is Deno?

Deno is a secure runtime for JavaScript and TypeScript that's built on V8, Rust, and Tokio. It features:

  • 🔒 Secure by default - No file, network, or environment access unless explicitly enabled
  • 🚀 TypeScript support - Built-in TypeScript compiler, no configuration needed
  • 📦 Modern module system - Native ES modules with URL imports
  • 🛠️ Built-in tooling - Includes formatter, linter, test runner, bundler, and more
  • 🌐 Web standard APIs - Compatible with browser APIs like fetch, WebSocket, and Web Workers
  • High performance - V8 engine with Rust-powered I/O

Installation

Using pip

pip install deno

Using uv (recommended)

uv add deno

Using poetry

poetry add deno

Usage

Command Line

Run Deno directly using uvx or pipx:

# Check version
uvx deno --version

# Run a script
uvx deno run https://examples.deno.land/hello-world.ts

# Start a REPL
uvx deno

With pipx:

pipx run deno --version

After installing with pip, the deno command is available in your PATH:

deno run --allow-net server.ts

Python API

Use the Python API to integrate Deno into your Python applications:

import deno
import subprocess

# Get the path to the Deno executable
deno_bin = deno.find_deno_bin()

# Run a Deno script from Python
result = subprocess.run(
    [deno_bin, "run", "--allow-net", "script.ts"],
    capture_output=True,
    text=True
)

print(result.stdout)

Example: Running TypeScript from Python

import deno
import subprocess
import tempfile
import os

# Create a temporary TypeScript file
ts_code = """
console.log("Hello from Deno!");
const data = { message: "TypeScript works!" };
console.log(JSON.stringify(data));
"""

with tempfile.NamedTemporaryFile(mode='w', suffix='.ts', delete=False) as f:
    f.write(ts_code)
    ts_file = f.name

try:
    # Execute with Deno
    result = subprocess.run(
        [deno.find_deno_bin(), "run", ts_file],
        capture_output=True,
        text=True
    )
    print(result.stdout)
finally:
    os.unlink(ts_file)

Platform Support

This package provides official Deno binaries for:

Platform Architectures
🍎 macOS x86_64 (Intel), arm64 (Apple Silicon)
🐧 Linux x86_64 (amd64), arm64 (aarch64)
🪟 Windows x86_64 (64-bit)

The appropriate binary for your platform is automatically downloaded and installed.

Common Use Cases

Running Deno Scripts in Python Projects

Integrate JavaScript/TypeScript functionality into your Python applications:

import deno
import subprocess

def run_deno_script(script_path: str, *args):
    """Execute a Deno script with arguments."""
    result = subprocess.run(
        [deno.find_deno_bin(), "run", "--allow-all", script_path, *args],
        capture_output=True,
        text=True
    )
    return result.stdout

output = run_deno_script("./scripts/process-data.ts", "input.json")

Using Deno as a Task Runner

Add Deno scripts to your Python project for tasks like:

  • Frontend asset building
  • API mocking
  • Data processing with TypeScript
  • Testing web APIs

CI/CD Integration

Install Deno in your CI/CD pipelines:

# GitHub Actions example
- name: Install Deno via pip
  run: pip install deno

- name: Run Deno tests
  run: deno test --allow-all

Why Use deno via PyPI?

  • Easy integration - Install Deno alongside Python dependencies
  • Version pinning - Lock Deno versions in requirements.txt or pyproject.toml
  • No manual downloads - Automatic binary management
  • Cross-platform - Works seamlessly across development and production environments
  • Python API - Programmatic access to Deno from Python code

Version Compatibility

The version of this package corresponds to the Deno version it distributes. For example:

  • deno==2.1.0 includes Deno v2.1.0
  • deno==2.0.0 includes Deno v2.0.0

Check the Deno releases for version details.

Resources

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

MIT

This repository redistributes official Deno binaries under the MIT license to make them easily installable via pip, uv, poetry, and other Python package managers.

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

deno-2.7.14.tar.gz (8.2 kB view details)

Uploaded Source

Built Distributions

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

deno-2.7.14-py3-none-win_amd64.whl (49.3 MB view details)

Uploaded Python 3Windows x86-64

deno-2.7.14-py3-none-manylinux_2_27_x86_64.whl (50.3 MB view details)

Uploaded Python 3manylinux: glibc 2.27+ x86-64

deno-2.7.14-py3-none-manylinux_2_27_aarch64.whl (48.3 MB view details)

Uploaded Python 3manylinux: glibc 2.27+ ARM64

deno-2.7.14-py3-none-macosx_11_0_arm64.whl (44.6 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

deno-2.7.14-py3-none-macosx_10_12_x86_64.whl (47.8 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

Details for the file deno-2.7.14.tar.gz.

File metadata

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

File hashes

Hashes for deno-2.7.14.tar.gz
Algorithm Hash digest
SHA256 63a79caa105368813e434593f2c059d4cc3e2562ec57f606348e9321a525d582
MD5 a4262666227b06db42b4c41bf7722d2c
BLAKE2b-256 30e4adbeb37143551a4e575049e8b291bedc5f57191753ade31f7cf6665b1d52

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.14.tar.gz:

Publisher: release.yml on denoland/deno_pypi

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

File details

Details for the file deno-2.7.14-py3-none-win_amd64.whl.

File metadata

  • Download URL: deno-2.7.14-py3-none-win_amd64.whl
  • Upload date:
  • Size: 49.3 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for deno-2.7.14-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 1646dbcd447465bc6eb9a9e25eef0283f74dd68ad5bd9c50bcaec641737eb730
MD5 9a5474ee08d9c78eab4ac1eea1ca961b
BLAKE2b-256 980e2581a39773004081f40ef4811059fe867953d86166b3f7fb77abb5d68757

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.14-py3-none-win_amd64.whl:

Publisher: release.yml on denoland/deno_pypi

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

File details

Details for the file deno-2.7.14-py3-none-manylinux_2_27_x86_64.whl.

File metadata

File hashes

Hashes for deno-2.7.14-py3-none-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 0a92040900311849a812d47e29e1494b1a4f4c7431536721888356c7a3662d22
MD5 4f5d1a51e6761009066d0396a2f4faab
BLAKE2b-256 79a8ea52407ebe29caadc67b6899437898880aad8d207ed889dd4f9ba7d9ddf7

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.14-py3-none-manylinux_2_27_x86_64.whl:

Publisher: release.yml on denoland/deno_pypi

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

File details

Details for the file deno-2.7.14-py3-none-manylinux_2_27_aarch64.whl.

File metadata

File hashes

Hashes for deno-2.7.14-py3-none-manylinux_2_27_aarch64.whl
Algorithm Hash digest
SHA256 f47511d0c8080c2bdb0ee58f2b96d657b1e5f2ede088b1bb9a98bfb80362af22
MD5 4cdb0ce266c3dabf6c8464274953b9ed
BLAKE2b-256 5251c60816c902e5fa9daf4bab5869a5895e58748f05739eab399c1ae6d0ee37

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.14-py3-none-manylinux_2_27_aarch64.whl:

Publisher: release.yml on denoland/deno_pypi

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

File details

Details for the file deno-2.7.14-py3-none-macosx_11_0_arm64.whl.

File metadata

  • Download URL: deno-2.7.14-py3-none-macosx_11_0_arm64.whl
  • Upload date:
  • Size: 44.6 MB
  • Tags: Python 3, macOS 11.0+ ARM64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for deno-2.7.14-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 194560abc29021d3b5b4be9bfd628f2b21152a3bae031bdcd30e41584ba4b9d8
MD5 e26428cb44d5a06a20d1f4d20fec82b1
BLAKE2b-256 fe1f809cac7474d86ad41f2938b4713cf846b261bba7a1fdb5ab27b3fabc435e

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.14-py3-none-macosx_11_0_arm64.whl:

Publisher: release.yml on denoland/deno_pypi

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

File details

Details for the file deno-2.7.14-py3-none-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for deno-2.7.14-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 3860efe76d9c8491ee847256f31ff5f1b1d1871137daab91eb4f28c0543eeb4d
MD5 a1f986d281078f486139a6b53e2de11d
BLAKE2b-256 c8a182951e37de914ca9445e3dd99a5f06e36e857000f9d34beb3f9fc5ff0971

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.14-py3-none-macosx_10_12_x86_64.whl:

Publisher: release.yml on denoland/deno_pypi

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