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.11.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.11-py3-none-win_amd64.whl (49.4 MB view details)

Uploaded Python 3Windows x86-64

deno-2.7.11-py3-none-manylinux_2_27_x86_64.whl (50.4 MB view details)

Uploaded Python 3manylinux: glibc 2.27+ x86-64

deno-2.7.11-py3-none-manylinux_2_27_aarch64.whl (48.4 MB view details)

Uploaded Python 3manylinux: glibc 2.27+ ARM64

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

Uploaded Python 3macOS 11.0+ ARM64

deno-2.7.11-py3-none-macosx_10_12_x86_64.whl (47.9 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

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

File metadata

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

File hashes

Hashes for deno-2.7.11.tar.gz
Algorithm Hash digest
SHA256 342a656fca446fadc261ed22af35693b6c34e79129fa2bd387a1e5d39f496a99
MD5 2822564f0eb772b1ece3cea9a4bd0e8f
BLAKE2b-256 d73fa0477c72b847c0082ceb8885261eb14fb4addde22e8fb0146c011636979b

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.11.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.11-py3-none-win_amd64.whl.

File metadata

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

File hashes

Hashes for deno-2.7.11-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 e2b69676e52543153b82e926f558983f9251db2251474f3225301cf7aca05a2b
MD5 3f014564b3a25458544d3daf2e368d1e
BLAKE2b-256 b68d7a801d85a0a8233d00ea1a381fd32e76c81be9db78ada162e211e7619221

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.11-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.11-py3-none-manylinux_2_27_x86_64.whl.

File metadata

File hashes

Hashes for deno-2.7.11-py3-none-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 58eea29d18fe8f80f2a4354d96225a31961ed3fa68336a7fcdd6add331df6acd
MD5 bd870cb64f1387f2a017a2614bb082f3
BLAKE2b-256 a01891d1ceb2e15b4446fcecdf4be17ed59b02f5b35d8c98c94e7eaadf10591e

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.11-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.11-py3-none-manylinux_2_27_aarch64.whl.

File metadata

File hashes

Hashes for deno-2.7.11-py3-none-manylinux_2_27_aarch64.whl
Algorithm Hash digest
SHA256 56578808c891d1daeadc279ac73445a24a83c2c721b37016fd92b1aa9224979b
MD5 2aaabd2aa78d30fb59c6256123a34f94
BLAKE2b-256 0151b8fcb7d6882d659abd678f48fc5bc89aa0aa10f5a399fca3823680f277ca

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.11-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.11-py3-none-macosx_11_0_arm64.whl.

File metadata

  • Download URL: deno-2.7.11-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.7

File hashes

Hashes for deno-2.7.11-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 a1dd1ceb0c2109b54334a621503e5297d473f5c3e6702992dfa68d9b7cdf1177
MD5 4f85f2b6dcf6271a9b00518c190ac13c
BLAKE2b-256 27f3250216e71e21cfc291ff6eb6503a479410ff927c9f97ebb644463c620692

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.11-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.11-py3-none-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for deno-2.7.11-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 76aa633656b07f64cfda3aa94a1e16bc123034ba2fe676d23b179f8326728534
MD5 f669a5fe6ebc0a86e80a6fc645211673
BLAKE2b-256 d164c8cb5a9c50135ada59b412b7511852d551d2618e169f48a8e7b8e90a382a

See more details on using hashes here.

Provenance

The following attestation bundles were made for deno-2.7.11-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