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

Uploaded Python 3Windows x86-64

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

Uploaded Python 3manylinux: glibc 2.27+ x86-64

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

Uploaded Python 3manylinux: glibc 2.27+ ARM64

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

Uploaded Python 3macOS 11.0+ ARM64

deno-2.7.2-py3-none-macosx_10_12_x86_64.whl (46.3 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

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

File metadata

  • Download URL: deno-2.7.2.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.2.tar.gz
Algorithm Hash digest
SHA256 3dc9461ac4dd0d6661769f03460861709e17c4e516dfce14676e6a3146824b7b
MD5 41d5433608d3533cb558ac353047004d
BLAKE2b-256 bd29b2941d53d94094e20e52def86956528140dbe60b49d715803f7e9799d42f

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.2-py3-none-win_amd64.whl
  • Upload date:
  • Size: 48.3 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.2-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 5d525d270e16d5ea22ad90a65e1ebc0dff8b83068d698f6bad138bfa857e4d28
MD5 9fac5ec3f93814de9082f1d2f21c24d8
BLAKE2b-256 7907b332f98969937d435ba2905195a0b3dd2162f192659595dde88c615b04e1

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.2-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.2-py3-none-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 bded39ebc9d19748a13a4c046a715f12c445a3e15c0b4cde6d42cc47793efcf0
MD5 737553ca3ff854060636991ee2c8adbc
BLAKE2b-256 e614bfac1928082f78f120aaff7608f211a8beab8f66e72defc0ac85d6f52f84

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.2-py3-none-manylinux_2_27_aarch64.whl
Algorithm Hash digest
SHA256 f7b63f13c9fdeb18d0435e80aa4677878ac1b9ac23a49c7570958b9d81772e06
MD5 c8652dccc4d30252da7ad6fe90c52880
BLAKE2b-256 38f0c415c08ca30fb084887a96b88df7f6511c98575b365db87b0fac76a82773

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: deno-2.7.2-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.2-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 a19f75d7a148a2d030543db88734f03648e31dc7385a9c62aa1d975e2b0df8d9
MD5 a36df995b51803dae395f2d175dc8646
BLAKE2b-256 83ce085c3002cdfc0d33b30896b3d1469024c23e3971cba4a15ae3983c48d2e4

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for deno-2.7.2-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 67509919fa9df639d9375e441648ae5a3ab9bb1ce6fcddc21c49c08368af4d68
MD5 2cb8ca7130a6b4e6a9a74e3d6033ed3a
BLAKE2b-256 0ca09e6f45c25ef36db827e75bd35bf9378c196a6bed2804a8259d1d63bab84f

See more details on using hashes here.

Provenance

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