enkeksi takes a markdown-formatted input and executes the sql queries found in it, and returns a pretty markdown-formatted output where the results of the SQL queries have been added. To make usage of package easy, enkeksi comes with a command line tool markdown-sql-eval which can be used to process markdown files. Project is developed and hosted in GitHub: https://github.com/ahojukka5/enkeksi.
Project description
enkeksi - Markdown-SQL evaluator
Package author: Jukka Aho (@ahojukka5, ahojukka5@gmail.com)
enkeksi takes a markdown-formatted input and executes the sql queries found in it, and returns a markdown-formatted output where the results of the sql queries have been added. Package can be used, for example, to create a dynamic project documentation where SQL queries are automatically executed to get example results in a dynamic manner. This way it is easy to spot from the non-working documentation is there is problems with the database.
enkeksi comes with a command line tool markdown-sql-eval
which can be used
to process markdown files efficiently.
Project is hosted in GitHub: https://github.com/ahojukka5/enkeksi.
Documentation is hosted in ReadTheDocs: https://enkeksi.readthedocs.io/.
Installing package
To install the most recent package from Python Package Index (PyPi), use git:
pip install enkeksi
To install the development version, you can install the package directly from the GitHub:
pip install git+git://github.com/ahojukka5/enkeksi.git
CLI Usage
Consider the following demo markdown file:
# Sample file
Hello, this is a sample file. Below, we initialize some test data to sqlite
database. It doesn't show in the final output, because of `--hide-input` flag.
```sql
--hide-input
CREATE TABLE Movies (id INTEGER PRIMARY KEY, name TEXT, year INTEGER);
INSERT INTO Movies (name, year) VALUES ("Snow White", 1937);
INSERT INTO Movies (name, year) VALUES ("Fantasia", 1940);
```
To list the content of the database, we need to use `SELECT` in SQL query. We
can use extra option `--caption='Table: Movies'` to add caption to output:
```sql
--hide-input --caption='Table: Movies'
SELECT * FROM Movies;
```
SQL results are formatted using [tabulate](https://pypi.org/project/tabulate/).
Using option `--table-format` we can change how the end results looks like.
By default, `psgl` is used and there rest options can be found from tabulate's
documentation. The total number of rows in database is:
```sql
--caption='With psql formatting'
SELECT COUNT(*) AS 'Number of movies in database' FROM Movies;
```
Option `--hide-headers` can be used to hide the header row of the result.
```sql
--table-format='github' --hide-headers --caption='With github formatting and headers removed'
SELECT COUNT(*) AS 'Now shown' FROM Movies;
```
Processing the file with markdown-sql-eval
:
markdown-sql-eval examples/example2.md > examples/example2_rendered.md
Result is:
# Sample file
Hello, this is a sample file. Below, we initialize some test data to sqlite
database. It doesn't show in the final output, because of `--hide-input` flag.
To list the content of the database, we need to use `SELECT` in SQL query. We
can use extra option `--caption='Table: Movies'` to add caption to output:
```text
Table: Movies
+------+------------+--------+
| id | name | year |
|------+------------+--------|
| 1 | Snow White | 1937 |
| 2 | Fantasia | 1940 |
+------+------------+--------+
```
SQL results are formatted using [tabulate](https://pypi.org/project/tabulate/).
Using option `--table-format` we can change how the end results looks like.
By default, `psgl` is used and there rest options can be found from tabulate's
documentation. The total number of rows in database is:
```sql
SELECT COUNT(*) AS 'Number of movies in database' FROM Movies;
```
```text
With psql formatting
+--------------------------------+
| Number of movies in database |
|--------------------------------|
| 2 |
+--------------------------------+
```
Option `--hide-headers` can be used to hide the header row of the result.
```sql
SELECT COUNT(*) AS 'Now shown' FROM Movies;
```
```text
With github formatting and headers removed
|---|
| 2 |
```
The generated markdown file can then be added to your project documentation
and hosted using e.g. mkdocs. For that idea, take a look of docs/demo.md
,
which is hosted in here,
and generated from docs/demo_tmpl.md
.
Contributing
Contributions are welcome as usual. If you have any good idea, and especially, a better name for a package, raise an issue.
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
Built Distribution
File details
Details for the file enkeksi-0.2.1.tar.gz
.
File metadata
- Download URL: enkeksi-0.2.1.tar.gz
- Upload date:
- Size: 5.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0ac5ed64bfda7e3c6ed0f13f61260a846da0c6dc7ca3e85c10ce7e93e8708ddc |
|
MD5 | 5a9112ae29e2dd053820af63caa66750 |
|
BLAKE2b-256 | 9edbcf79dfca28824a0accaa3da12162fea0b8bc3a89ba414f41c55340e28cec |
File details
Details for the file enkeksi-0.2.1-py3-none-any.whl
.
File metadata
- Download URL: enkeksi-0.2.1-py3-none-any.whl
- Upload date:
- Size: 5.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b5861b1b30f2381bb9c9339cd4dee4b98fc6bbb715b11a7bba647d1714c21202 |
|
MD5 | 438e73e394acf33070cd7cd9ca614fc0 |
|
BLAKE2b-256 | 02e2d6fa8e0170fb0d4ed5a89c2a019b7048f969f82da7a117d2a3807530b145 |