Skip to main content

Pretty-print and format SQL queries for debugging

Project description

philiprehberger-sql-print

Tests PyPI version Last updated

Pretty-print and format SQL queries for debugging.

Installation

pip install philiprehberger-sql-print

Usage

Format SQL

from philiprehberger_sql_print import format_sql

query = "SELECT id, name FROM users WHERE active = 1 AND role = 'admin' ORDER BY name"
print(format_sql(query))

Output:

SELECT id, name
FROM users
WHERE active = 1
  AND role = 'admin'
ORDER BY name

Print SQL with syntax highlighting

from philiprehberger_sql_print import print_sql

print_sql("SELECT * FROM orders LEFT JOIN users ON orders.user_id = users.id WHERE total > 100")

Prints formatted SQL with ANSI color-coded keywords, strings, and numbers.

Disable colors or uppercase

from philiprehberger_sql_print import print_sql

# No ANSI colors (useful for logging)
print_sql("select id from users", color=False)

# Preserve original keyword casing
print_sql("select id from users", uppercase=False)

Custom indentation

from philiprehberger_sql_print import format_sql

print(format_sql("SELECT id FROM users WHERE active = 1", indent=4))

API

Function Description
format_sql(sql, *, indent=2, uppercase=True) -> str Format a SQL query with newlines and indentation.
print_sql(sql, *, indent=2, uppercase=True, color=True, file=None) -> None Print a formatted SQL query with optional ANSI syntax highlighting.

Parameters

Parameter Type Default Description
sql str The SQL query string to format.
indent int 2 Number of spaces for indentation.
uppercase bool True Whether to uppercase SQL keywords.
color bool True Whether to apply ANSI color codes (print_sql only).
file TextIO | None None Output stream. Defaults to sys.stdout (print_sql only).

Development

pip install -e .
python -m pytest tests/ -v

Support

If you find this project useful:

Star the repo

🐛 Report issues

💡 Suggest features

❤️ Sponsor development

🌐 All Open Source Projects

💻 GitHub Profile

🔗 LinkedIn Profile

License

MIT

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

philiprehberger_sql_print-0.1.7.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

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

philiprehberger_sql_print-0.1.7-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file philiprehberger_sql_print-0.1.7.tar.gz.

File metadata

File hashes

Hashes for philiprehberger_sql_print-0.1.7.tar.gz
Algorithm Hash digest
SHA256 bca90c68c88064aaa6da5abe91d55d1454ff142ec65ad1746007d93cba408d75
MD5 c5e526fec20559a75002ecd3d3ccd361
BLAKE2b-256 ae51bfdab41d428ffcbb8581a4f155f0a83c0c601a86fde52e79efaafa495cfa

See more details on using hashes here.

File details

Details for the file philiprehberger_sql_print-0.1.7-py3-none-any.whl.

File metadata

File hashes

Hashes for philiprehberger_sql_print-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 a287bfdf34b4d9bf9f81993848db458ea034d76fbe049c655baa42a9bb1b860d
MD5 2e49d65f4d01a3f99340e712d7d068dd
BLAKE2b-256 3e003d60acd464eb154512192d9009755e5e2c0238f47cc4bb2bce88fd5c8124

See more details on using hashes here.

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