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

Uploaded Python 3Windows x86-64

deno-2.7.4-py3-none-manylinux_2_27_x86_64.whl (49.0 MB view details)

Uploaded Python 3manylinux: glibc 2.27+ x86-64

deno-2.7.4-py3-none-manylinux_2_27_aarch64.whl (47.0 MB view details)

Uploaded Python 3manylinux: glibc 2.27+ ARM64

deno-2.7.4-py3-none-macosx_11_0_arm64.whl (43.3 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

deno-2.7.4-py3-none-macosx_10_12_x86_64.whl (46.4 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

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

File metadata

  • Download URL: deno-2.7.4.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.4.tar.gz
Algorithm Hash digest
SHA256 262e0a6bee1a4a218a52baf433b96783ae3751440be3d3af195a1bf46ac39fe8
MD5 5a9a4611bf2d38434a1c3e1a9ce68dbe
BLAKE2b-256 9c493abb94488985e282c85fceb0d316c765a3a027947e8628ec009c8e946928

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.4-py3-none-win_amd64.whl
  • Upload date:
  • Size: 48.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.4-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 d7fc9a55d8ef919b17752386791bda20ac6bd58f874223541b8f6a877f5f83e9
MD5 96fe6d97741586ec13d0ec48a1878d5c
BLAKE2b-256 1f653a5ff9e16ae52319627c331363e52f4266e5f69a013169846bb26ebb42d5

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.4-py3-none-manylinux_2_27_x86_64.whl
  • Upload date:
  • Size: 49.0 MB
  • Tags: Python 3, manylinux: glibc 2.27+ x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for deno-2.7.4-py3-none-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 2fa937d81e96b89d82ab62ed1b448eb842e35ee8baa0f4aeca0857e431235cf0
MD5 52c5722ea59551acf995046af4f025e5
BLAKE2b-256 c67c33be6934ee31e4d2ff5b23d8ebf34c8b5170d8ec134bb033bee7b75c9573

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.4-py3-none-manylinux_2_27_aarch64.whl
Algorithm Hash digest
SHA256 4489e8db4d002724b40b32c5be988e6628de882abcd4aae612fc2267349f9e40
MD5 41290dc7079117c27f2bdda11f8cfa58
BLAKE2b-256 c053fd9ad124ad9710c554d6cc7a49e9bd9d1b5077eb37258d34e8a69070395d

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.4-py3-none-macosx_11_0_arm64.whl
  • Upload date:
  • Size: 43.3 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.4-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 e46b936f433f6130012acd3960bd9519148bf4dd8b5c1b0e0e278ea558ec1859
MD5 366e81412b6eb50647199215acfdaf6b
BLAKE2b-256 e6ec1d015a1c19203977ba79b2c8de710872da6e09659df8ded55470ac34732f

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.4-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 8e53b7118f9cd61af22da63468d21e94507a4be74dd4ce523cffcaea047509b6
MD5 f8107f8a0fb8ff44fafc003ff8307dd0
BLAKE2b-256 f650f9bd1ffa8190e95a6134cb2727be49313e3c23bf3c7e79a09146f881834e

See more details on using hashes here.

Provenance

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