Skip to main content

Transform text into beautiful markdown, effortlessly.

Project description



mdfy teaser

test latest version Documentation Status PyPI Downloads

mdfy

mdfy is a Python library that makes creating markdown documents as simple as writing Python code. Generate reports, documentation, and structured content with an intuitive, object-oriented API.

🚀 Quick Start

Installation

pip install mdfy

Usage

from mdfy import Mdfier, MdHeader, MdText, MdTable
# Create markdown content
content = [
    MdHeader("My Report"),
    MdText("This quarter's sales were [excellent:bold]!"),
    MdTable([
        {"Product": "Laptop", "Sales": 1200, "Growth": "+15%"},
        {"Product": "Phone", "Sales": 800, "Growth": "+8%"}
    ])
]
# Generate markdown file
Mdfier("report.md").write(content)

📖 Documentation

Resource Description
Getting Started Step-by-step tutorial for beginners
User Guide Complete feature documentation
Examples Real-world usage examples
API Reference Complete API documentation

Basic Features

Feature Description
Text styling Format text with bold, italic, and more - even in the middle of text
Headers Multiple levels for document structure
Links Internal and external linking
Lists Ordered and unordered with nesting support
Tables From dictionaries and lists with formatting
Images With alt text and titles
Code blocks With syntax highlighting
Quotes For emphasis and citations
Horizontal rules For section separation
Table of Contents Automatic generation from headers

Basic Usage

import mdfy as m

# Create content
content = [
    m.header("My Report"),
    m.text("This quarter's sales were [excellent:bold]!"),
    m.table(
        [
            {"Product": "Laptop", "Sales": 1200, "Growth": "+15%"},
            {"Product": "Phone", "Sales": 800, "Growth": "+8%"},
        ]
    ),
]

# Generate markdown file
m.Mdfier.from_filepath("report.md").write(content)

Output:

# My Report

This quarter's sales were [excellent:bold]!

| Product | Sales | Growth |
| --- | --- | --- |
| Laptop | 1200 | +15% |
| Phone | 800 | +8% |

🎨 Core Elements

Headers & Text

MdHeader("Title", level=1)                    # # Title
MdText("[Bold:bold] and [italic:italic]")     # **Bold** and *italic*

Data & Lists

MdTable(data, precision=2)                    # Convert dicts/lists to tables
MdList(items, numbered=True)                  # • Bullet or 1. Numbered lists

Code & More

MdCode("print('hello')", syntax="python")     # Syntax-highlighted code blocks

You can use a shortened syntax for convenience:

import mdfy as m
# Create a header
header = m.header("My Report", level=1)        # # My Report
text = m.text("This quarter's sales were [excellent:bold]!")
table = m.table([
    {"Product": "Laptop", "Sales": 1200, "Growth": "+15%"},
    {"Product": "Phone", "Sales": 800, "Growth": "+8%"}
])

💡 Real-world Examples

Dynamic Reports

import mdfy as m

def generate_sales_report(sales_data):
    total = sum(item['amount'] for item in sales_data)
    return [
        m.header("Sales Report"),
        m.text(f"Total Revenue: [${total:,}:bold]"),
        m.table(sales_data, precision=2)
    ]

m.Mdfier.from_filepath("sales.md").write(generate_sales_report(quarterly_data))

Data Analysis

# Convert pandas DataFrame to markdown table
df_summary = df.describe()
table = MdTable(df_summary.to_dict(), precision=3)

# Create analysis report
analysis = [
    MdHeader("Data Analysis Report"),
    MdText("Dataset contains [1,000:bold] records with [95%:bold] completeness."),
    MdTable(df_summary.to_dict(), precision=3)
]

🔧 Advanced Features

  • Nested Content: Organize content hierarchically
  • Custom Formatting: Flexible text styling with [text:style] syntax
  • Table Customization: Headers, row labels, precision control, transposition
  • Independent Elements: Each element can be used standalone
  • Type Safety: Full type hints for better IDE support
  • ""Table of Contents**: Automatically generated from headers

🤝 Contributing

We welcome contributions! Here's how to get started:

# Development setup
git clone https://github.com/argonism/mdfy.git
cd mdfy
uv sync --all-groups

# Run tests
python -m pytest

Areas we'd love help with:

  • 🐛 Bug reports and fixes
  • 📚 Documentation improvements
  • ✨ New element types
  • 🎨 Styling and formatting features

📜 License

This project is licensed under the MIT License.

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

mdfy-0.11.0.tar.gz (19.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mdfy-0.11.0-py3-none-any.whl (22.3 kB view details)

Uploaded Python 3

File details

Details for the file mdfy-0.11.0.tar.gz.

File metadata

  • Download URL: mdfy-0.11.0.tar.gz
  • Upload date:
  • Size: 19.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mdfy-0.11.0.tar.gz
Algorithm Hash digest
SHA256 fc480509f1738e92537d407f72e04d63ad73f1d840f6ea84f7244be741fdbc7d
MD5 0a90c00b38832cf5ee5288555d5563b0
BLAKE2b-256 213994870d31feeb60c25ac4ad56a521135724cfe91f7117dd33657983b117b0

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdfy-0.11.0.tar.gz:

Publisher: publish.yml on mdfy-org/mdfy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mdfy-0.11.0-py3-none-any.whl.

File metadata

  • Download URL: mdfy-0.11.0-py3-none-any.whl
  • Upload date:
  • Size: 22.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mdfy-0.11.0-py3-none-any.whl
Algorithm Hash digest
SHA256 830b03e2a7c0b512b2b96acba8106c9e4d618e0103b7be1ebdfe8e68e3534934
MD5 e0e3f72e26f4c660992e6b60ce1aca7a
BLAKE2b-256 914d0d171539c3b1079052da2cb1f17a1a3ab033e22ae4652225c3945616f0c4

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdfy-0.11.0-py3-none-any.whl:

Publisher: publish.yml on mdfy-org/mdfy

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