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

Uploaded Python 3Windows x86-64

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

Uploaded Python 3manylinux: glibc 2.27+ x86-64

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

Uploaded Python 3manylinux: glibc 2.27+ ARM64

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

Uploaded Python 3macOS 11.0+ ARM64

deno-2.7.10-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.10.tar.gz.

File metadata

  • Download URL: deno-2.7.10.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.10.tar.gz
Algorithm Hash digest
SHA256 ea30a61f98c9a57b80f80a525a1d4687e36b7fcca133f813439c8431489e703b
MD5 b49444684aa83203c05f211c79a416b8
BLAKE2b-256 e801c03ed7db9adbd02a45de56037e2b685adc730775e8878229881ed907458d

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.10-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.10-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 3c2ee1773cf48b0fe9e74d23da3b6f9b685240e90db81ce6f5c8c0922c08b992
MD5 c8b9f0a543938e6576f8cd6aa68c694c
BLAKE2b-256 c7a9423f671846107bed51c405bbd1e32782f0b39edd5d075e4f806b8eea77f5

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.10-py3-none-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 1f4aab0be642692205df91e39eff1db774d6b4c5d8dfcff0669d014fd0c80cba
MD5 0f36696bedd0339de5529e72ade01c4b
BLAKE2b-256 dc13a41c3aba09103cd31ddbe2fc8fc98df5118df7b23d4cee248926367c6469

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.10-py3-none-manylinux_2_27_aarch64.whl
Algorithm Hash digest
SHA256 b415a36b63e3c5c478180a5cc0e9f517095005086144dbe52b34268b397c404b
MD5 cda3cfae2436472286e3f2c2dc810f6e
BLAKE2b-256 e6daf77fd4852d84063728d618b9f4c088b31d27a999b6dfc3dd1f9623dd56a9

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.10-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.10-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 6c4c03e583c4c4d5647ec97690038a4b7c00a7ad076949b5ce26203857b1c85a
MD5 4759de0875383df7c0d6175cc63ae821
BLAKE2b-256 b5dad572cf9f195aaf317a0e222af10f8adf3f3acfd114f80fec78c110fb66e6

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.10-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 4e361633c1ce6ec439d312911ec230e4e060c4e5ca957e8f58823129af511b13
MD5 5ed0745a0e9dabbe747bb318b0ccb3c3
BLAKE2b-256 394ba28d8c7ff5d797f52098dcbce91b3ff8394bdbd0dd07cb4c87b032ead539

See more details on using hashes here.

Provenance

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