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

Uploaded Python 3Windows x86-64

deno-2.7.12-py3-none-manylinux_2_27_x86_64.whl (50.2 MB view details)

Uploaded Python 3manylinux: glibc 2.27+ x86-64

deno-2.7.12-py3-none-manylinux_2_27_aarch64.whl (48.2 MB view details)

Uploaded Python 3manylinux: glibc 2.27+ ARM64

deno-2.7.12-py3-none-macosx_11_0_arm64.whl (44.5 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

deno-2.7.12-py3-none-macosx_10_12_x86_64.whl (47.7 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

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

File metadata

  • Download URL: deno-2.7.12.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.12.tar.gz
Algorithm Hash digest
SHA256 7ef413693b4a9d86837a6f4991738429908f6f42f6f3ed85254ab0e679438049
MD5 4f26024513394d83cbedbf944fb90840
BLAKE2b-256 5cac39b45b51e7aaf9cad1de36f91bd58677818a7d7a867fa0721faff43b67c4

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.12-py3-none-win_amd64.whl
  • Upload date:
  • Size: 49.2 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.12-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 ddeeb03427d7ce0979a395ae2d1aa5ebcddeb97ab0fd9e7dfa56a08e0e5b817c
MD5 98239a1f2e7bace329c615fbf2790804
BLAKE2b-256 07b0c6c215eca2aa54b700a95867901832245518b2f217edfc78e733401bf8b3

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.12-py3-none-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 b396675fef296530c386387990d26d118398452bac47541e739b353b9ff8809f
MD5 9e708da51b54f376302a2ff122a0590e
BLAKE2b-256 d707d8ba3284e098128076cd9f84e85d2e62d12fa1e5b8e5c47681983017af1a

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.12-py3-none-manylinux_2_27_aarch64.whl
Algorithm Hash digest
SHA256 ab7c12ee0e10cd232dbb8f7cf5802bfdbcc3462c0b1453726b158d8a27d4185f
MD5 87c73dd8c2440a2e06addfeb42fa9d3e
BLAKE2b-256 ce68ce111604f5877220e53fb10c5180ffaa484f829f20fcbc7f7115a90afadd

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.12-py3-none-macosx_11_0_arm64.whl
  • Upload date:
  • Size: 44.5 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.12-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 acf94fa815ac84a948b196f53a7e088ed126ec2e390a25d92cdfdc8c5d8a851e
MD5 c53232c82b025fa4530808cfb7632227
BLAKE2b-256 8d44ca1de5368b193c9819c57d505ff8ceb86dc38e2e87856b23c23b58abd234

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.12-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 74677d1be23426b1f16ce33c1a96868bc7554e1d41a12fb4d446017bb1955d1d
MD5 d68f72df1035b6d70d5bdcff11b0131a
BLAKE2b-256 77f00be717182294e9b61e58cd89b88d1b711c7e9c134e53890474b8d1e95704

See more details on using hashes here.

Provenance

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