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

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for philiprehberger_sql_print-0.1.2.tar.gz
Algorithm Hash digest
SHA256 07cf0070b1ff6aa1155fcf5010e208b4c8e9a353f6ff36c42da4b254fa66cb57
MD5 dd32d4d2ba91e7f6be4f7cde9fba0b19
BLAKE2b-256 5e067884587b660d91e4d08ed35bfe211fa5f1bce81730c7e5892e004be1b7d0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for philiprehberger_sql_print-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 574c7ce28563ec4d7cee6b0c80b8102f49f683db2f49e56339e72cab4119ac3a
MD5 bbc38623e97283e244150a258c1eaf1e
BLAKE2b-256 c2b2dc69090a353ad44ef1f7ba29c4ea8ed0e7abda1995355e5dd2d66441a122

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