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.5.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.5-py3-none-any.whl (63.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: markdown_table_fixer-0.1.5.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.5.tar.gz
Algorithm Hash digest
SHA256 2496e7d243b3f7ada59a0e22ddff06cd431b16b59eaac6e8c38d78c9ef40cd0d
MD5 22edff9ac4d08ab5e7f2d9d6455ebc2a
BLAKE2b-256 d9a7c0afa48973508d5bac5c8bbb073b2b72d376a34a9de11fd5d663bceba804

See more details on using hashes here.

Provenance

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

Publisher: build-test-release.yaml on modeseven-lfit/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.5-py3-none-any.whl.

File metadata

File hashes

Hashes for markdown_table_fixer-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 46c9561670a83d352fe7c3d082b8e1f161dd490054d631be97e7f3e3a75cbe5d
MD5 52b5a1b82d89d050c64f7bdc1252ab2c
BLAKE2b-256 298042329ac6aae97c37c92458507a96b2c828fcddb2b27bc99ec472afbd258e

See more details on using hashes here.

Provenance

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

Publisher: build-test-release.yaml on modeseven-lfit/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