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

Development

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

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

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for philiprehberger_sql_print-0.1.4.tar.gz
Algorithm Hash digest
SHA256 03e1074f89e6b3b9274095ed73475532517886162c542498f694d1f4e2f19b5c
MD5 70a86ba944fe45aab8b86e0abafd7aa7
BLAKE2b-256 a339c8c0d23cd5d34cd065cfc1b6eb370a782811d5215ac2c7bb4f75cf1c3531

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for philiprehberger_sql_print-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 56555fc23a64123f6bbd8c5062db2f6beb3210b7a96bd0910d71241937fb71b7
MD5 445315d552cc976da2a148dd14f6c562
BLAKE2b-256 bc4dd0732d1c6e266aae72f91677d18749ce34866e492f6c68aaf79d2dba6bea

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