Skip to main content

Pretty-print and format SQL queries for debugging

Project description

philiprehberger-sql-print

Tests PyPI version License

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).

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.1.tar.gz (5.5 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.1-py3-none-any.whl (5.2 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for philiprehberger_sql_print-0.1.1.tar.gz
Algorithm Hash digest
SHA256 967b242e622c9b09897bac64df4ae51ae5f7790b67870e015490fdb80eac4775
MD5 d3bca063312d601927ffd9a595325b5d
BLAKE2b-256 2d6212eebaf193266a630f115d32f42085c1d6b12e0bd9c57b3ec34f263fe258

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for philiprehberger_sql_print-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 899b49c920410f51cf15affa8342788ddd1ecb6ad8440b3c014f6ae373e3d2c2
MD5 fe5c82a3533954460abb7b56bf5e4d4e
BLAKE2b-256 81e53ed48f77d3565583378dd1cd4b187f48c6c93302cb4033e376bbba321dbd

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