Skip to main content

Markdown table formatter and linter with GitHub integration

Project description

🛠️ Markdown Table Fixer

A modern Python tool for automatically fixing markdown table formatting issues. Works as a standalone CLI tool, pre-commit hook, and can bulk-fix tables across GitHub organizations.

Features

  • Lint Mode: Scan directories for markdown files with table formatting issues
  • GitHub Mode: Automatically fix tables in blocked PRs across an entire GitHub organization
  • Pre-commit Integration: Run as a pre-commit hook to enforce table formatting standards
  • Markdownlint Compatible: Fixes issues detected by markdownlint's MD060 rule
  • Parallel Processing: Efficiently processes repositories and PRs in parallel

Installation

pip install markdown-table-fixer

Or with uv:

uv pip install markdown-table-fixer

Usage

Lint Mode

Scan the current directory for markdown table formatting issues:

markdown-table-fixer lint

Scan a specific path:

markdown-table-fixer lint /path/to/docs

Auto-fix issues found:

markdown-table-fixer lint --auto-fix

Respecting Markdownlint Disable Comments

The tool automatically respects markdownlint disable/enable comments in your markdown files. Violations within disabled sections are not reported:

<!-- markdownlint-disable MD013 -->
| Long table that exceeds line length... |
<!-- markdownlint-enable MD013 -->

<!-- markdownlint-disable MD013 MD060 -->
| Table with both line length and formatting issues disabled |
<!-- markdownlint-enable MD013 MD060 -->

This behavior is consistent across both lint and github commands, ensuring that locally suppressed violations are not reported or fixed when processing pull requests.

Violation Reporting

The lint command provides detailed violation reporting by markdownlint rule code:

$ markdown-table-fixer lint .
🔍 Scanning: .

Summary:
  Files scanned: 10
  Files with issues: 1
  Total violations: 66

Files with issues:
  README.md [66 Errors: MD013 (61), MD060 (5)]

The tool reports violations categorized by markdownlint rule:

  • MD013: Line length exceeds limit (auto-detected from .markdownlintrc)
  • MD060: Table formatting issues (misaligned pipes, spacing, etc.)

Note: Violations in sections with markdownlint disable comments are automatically filtered out and not reported.

The line length limit is automatically detected from your markdownlint configuration file (.markdownlint.json, .markdownlint.yaml, etc.). If no configuration file exists, the default is 80 characters.

GitHub Mode

The github command intelligently handles both individual pull requests and entire organizations.

Fix a Specific Pull Request

Fix markdown tables in a specific pull request by providing the PR URL:

markdown-table-fixer github https://github.com/owner/repo/pull/123 --token YOUR_GITHUB_TOKEN

With environment variable for token:

export GITHUB_TOKEN=your_token_here
markdown-table-fixer github https://github.com/owner/repo/pull/123

Dry run to preview changes without applying them:

markdown-table-fixer github https://github.com/owner/repo/pull/123 --dry-run

Update Methods

The tool supports two methods for applying fixes:

API Method (default) - Uses GitHub API to create new commits:

markdown-table-fixer github https://github.com/owner/repo/pull/123
  • Creates new commits via GitHub API
  • Shows as "Verified" by GitHub
  • No Git operations required
  • Faster and simpler
  • Does not support sync strategies (rebase/merge)

Git Method - Clones repo, amends commit, force-pushes:

markdown-table-fixer github https://github.com/owner/repo/pull/123 \
  --update-method git
  • Respects your local Git signing configuration
  • Amends the existing commit (preserves commit history)
  • Requires Git operations (clone, amend, push)
  • Use when you need to amend commits or use sync strategies

Scope Control

By default, both methods scan and fix all markdown files in the repository. To limit processing to files changed in the PR, use the --pr-changes-only flag:

markdown-table-fixer github https://github.com/owner/repo/pull/123 \
  --pr-changes-only

Benefits of limiting scope to PR changes:

  • Faster processing (fewer files to check)
  • Useful when you want to fix tables in modified files without touching others
  • Avoids touching unrelated markdown files

Fix PRs Across an Organization

Scan and fix tables in PRs across an entire GitHub organization:

markdown-table-fixer github ORG_NAME --token YOUR_GITHUB_TOKEN

Or using an organization URL:

markdown-table-fixer github https://github.com/ORG_NAME/

You can also provide the GitHub token via the GITHUB_TOKEN environment variable:

export GITHUB_TOKEN=your_token_here
markdown-table-fixer github ORG_NAME

Pre-commit Integration

Add to your .pre-commit-config.yaml:

repos:
  - repo: https://github.com/lfit/markdown-table-fixer
    rev: v1.0.0
    hooks:
      - id: markdown-table-fixer
        # Automatically fixes issues

Or use the check variant for validation without auto-fixing:

repos:
  - repo: https://github.com/lfit/markdown-table-fixer
    rev: v1.0.0
    hooks:
      - id: markdown-table-fixer-check
        # Validates, doesn't fix

Available hooks:

  • markdown-table-fixer: Automatically fixes table formatting issues
  • markdown-table-fixer-check: Checks for issues without fixing (CI mode)

Table Formatting Rules

The tool enforces the following formatting standards:

  1. Alignment: All pipe symbols (|) must be vertically aligned
  2. Spacing: Cell content must have at least one space on each side
  3. Consistency: All rows in a table must follow the same formatting style

Correct Format

Name Required Description
input False Action input
verbose True Enable logs

Incorrect Format (Fixed Automatically)

| Name    | Required | Description  |
| ------- | -------- | ------------ |
| input   | False    | Action input |
| verbose | True     | Enable logs  |

Options

Lint Command

Flag Short Default Description
--auto-fix false Automatically fix issues found
--format text Output format: text, json
--quiet -q false Suppress output except errors
--check false Exit with error if issues found

GitHub Command

Flag Short Default Description
--token -t None GitHub token (or use $GITHUB_TOKEN)
--threads auto Number of parallel threads
--dry-run false Preview changes without applying
--format table Output format: table, json
--include-drafts false Include draft PRs

Development

Setup

git clone https://github.com/lfit/markdown-table-fixer.git
cd markdown-table-fixer
uv venv
source .venv/bin/activate
uv pip install -e ".[dev]"

Running Tests

pytest

Running Pre-commit Hooks

pre-commit install
pre-commit run --all-files

License

Apache-2.0

Contributing

Contributions are welcome! Please see our contributing guidelines for more information.

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

markdown_table_fixer-0.1.6.tar.gz (61.2 kB view details)

Uploaded Source

Built Distribution

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

markdown_table_fixer-0.1.6-py3-none-any.whl (63.9 kB view details)

Uploaded Python 3

File details

Details for the file markdown_table_fixer-0.1.6.tar.gz.

File metadata

  • Download URL: markdown_table_fixer-0.1.6.tar.gz
  • Upload date:
  • Size: 61.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for markdown_table_fixer-0.1.6.tar.gz
Algorithm Hash digest
SHA256 1a3ae28ebb711856786ddbbcf3cfe1f5c8f7d562748beb5b17bc673fa1189d54
MD5 248205b1682403f19258884022d25998
BLAKE2b-256 32491065e5f9d1a6968b736b86d43b854445305502a8cfb84dccb0ba45aebb05

See more details on using hashes here.

Provenance

The following attestation bundles were made for markdown_table_fixer-0.1.6.tar.gz:

Publisher: build-test-release.yaml on lfreleng-actions/markdown-table-fixer

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

File details

Details for the file markdown_table_fixer-0.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for markdown_table_fixer-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 ef9b0bd4d5df25aea4e88a52fc46f72c199768fe80fdcf965c3d9602979f27b2
MD5 a8f365d4426961fe8c72aadc836f25ca
BLAKE2b-256 f3c20846bc7ae64de5c0ee73b3d90f8fd8c1a6dd547b287abc5f342f2a1c703d

See more details on using hashes here.

Provenance

The following attestation bundles were made for markdown_table_fixer-0.1.6-py3-none-any.whl:

Publisher: build-test-release.yaml on lfreleng-actions/markdown-table-fixer

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