goldziher/html-to-markdown

Modern PHP API for the html_to_markdown native extension powered by the Rust html-to-markdown engine.

Maintainers

Package info

github.com/kreuzberg-dev/html-to-markdown

Language:HTML

Type:php-ext

Ext name:ext-html_to_markdown

pkg:composer/goldziher/html-to-markdown

Statistics

Installs: 55

Dependents: 0

Suggesters: 0

Stars: 560

Open Issues: 2

v4.0.0-rc.16 2025-12-22 09:57 UTC

README

Rust Python Node.js WASM Java Go C# PHP Ruby Elixir R C Documentation License Banner Discord

High-performance HTML to Markdown conversion powered by Rust. Ships as native bindings for Rust, Python, TypeScript/Node.js, Ruby, PHP, Go, Java, C#, Elixir, R, C (FFI), and WebAssembly with identical rendering across all runtimes.

Documentation | Live Demo | API Reference

Highlights

  • 150-280 MB/s throughput (10-80x faster than pure Python alternatives)
  • 12 language bindings with consistent output across all runtimes
  • Metadata extraction — title, headers, links, images, structured data (JSON-LD, Microdata, RDFa)
  • Visitor pattern — custom callbacks for content filtering, URL rewriting, domain-specific dialects
  • Table extraction — extract structured table data (cells, headers, rendered markdown) during conversion
  • Secure by default — built-in HTML sanitization via ammonia

Quick Start

# Rust
cargo add html-to-markdown-rs

# Python
pip install html-to-markdown

# TypeScript / Node.js
npm install @kreuzberg/html-to-markdown-node

# Ruby
gem install html-to-markdown

# CLI
cargo install html-to-markdown-cli
# or
brew install kreuzberg-dev/tap/html-to-markdown

See the Installation Guide for all languages including PHP, Go, Java, C#, Elixir, R, and WASM.

Part of the Kreuzberg Ecosystem

html-to-markdown is developed by kreuzberg.dev and powers the HTML conversion pipeline in Kreuzberg, a document intelligence library for extracting text from PDFs, images, and office documents.

Contributing

Contributions welcome! See CONTRIBUTING.md for setup instructions and guidelines.

License

MIT License — see LICENSE for details.