Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/latture/json2table
Converts JSON to an HTML table
https://github.com/latture/json2table
converter html html-table json python
Last synced: 2 months ago
JSON representation
Converts JSON to an HTML table
- Host: GitHub
- URL: https://github.com/latture/json2table
- Owner: latture
- License: mit
- Created: 2016-05-13T10:07:01.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2016-10-21T22:37:42.000Z (over 8 years ago)
- Last Synced: 2024-11-01T03:34:49.530Z (3 months ago)
- Topics: converter, html, html-table, json, python
- Language: Python
- Homepage:
- Size: 25.4 KB
- Stars: 58
- Watchers: 5
- Forks: 16
- Open Issues: 5
-
Metadata Files:
- Readme: README.rst
- License: LICENSE.txt
Awesome Lists containing this project
README
json2table
==========|Build Status| |Coverage Status|
.. |Build Status| image:: https://travis-ci.org/latture/json2table.svg?branch=master
:target: https://travis-ci.org/latture/json2table
.. |Coverage Status| image:: https://coveralls.io/repos/github/latture/json2table/badge.svg?branch=master
:target: https://coveralls.io/github/latture/json2table?branch=masterThis is a simple Python package that allows a JSON object to be converted to HTML. It provides a ``convert`` function that accepts a ``dict`` instance and returns a string of converted HTML. For example, the simple JSON object ``{"key" : "value"}`` can be converted to HTML via:
.. code:: python
>>> from json2table import convert
>>> json_object = {"key" : "value"}
>>> build_direction = "LEFT_TO_RIGHT"
>>> table_attributes = {"style" : "width:100%"}
>>> html = convert(json_object, build_direction=build_direction, table_attributes=table_attributes)
>>> print(html)
'keyvalue'The resulting table will resemble
+---------+-------+
| **key** | value |
+---------+-------+More complex parsing is also possible. If a list of ``dict``'s provides the same list of keys, the generated HTML with gather items by key and display them in the same column.
.. code:: json
{"menu": {
"id": "file",
"value": "File",
"menuitem": [
{"value": "New", "onclick": "CreateNewDoc()"},
{"value": "Open", "onclick": "OpenDoc()"},
{"value": "Close", "onclick": "CloseDoc()"}
]
}
}Output:
+----------+--------------+----------------+-----------+
| **menu** | **menuitem** | **onclick** | **value** |
+ + +----------------+-----------+
| | | CreateNewDoc() | New |
+ + +----------------+-----------+
| | | OpenDoc() | Open |
+ + +----------------+-----------+
| | | CloseDoc() | Close |
+ +--------------+----------------+-----------+
| | **id** | file |
+ +--------------+----------------+-----------+
| | **value** | File |
+----------+--------------+----------------+-----------+It might, however, be more readable if we were able to build the table from top-to-bottom instead of the default left-to-right. Changing the ``build_direction`` to ``"TOP_TO_BOTTOM"`` yields:
+----------------+-----------+-------+-----------+
| **menu** |
+----------------+-----------+-------+-----------+
| **menuitem** | **id**| **value** |
+----------------+-----------+-------+-----------+
| **onclick** | **value** | file | File |
+----------------+-----------+ + +
| CreateNewDoc() | New | | |
+----------------+-----------+ + +
| OpenDoc() | Open | | |
+----------------+-----------+ + +
| CloseDoc() | Close | | |
+----------------+-----------+-------+-----------+Table attributes are added via the ``table_attributes`` parameter. This parameter should be a ``dict`` of ``(key, value)`` pairs to apply to the table in the form ``key="value"``. If in our simple example before we additionally wanted to apply a class attribute of ``"table table-striped"`` we would use the following:
.. code:: python
>>> table_attributes = {"style" : "width:100%", "class" : "table table-striped"}
and convert just as before:
.. code:: python
>>> html = convert(json_object, build_direction=build_direction, table_attributes=table_attributes)
Details
-------
This module provides a single ``convert`` function. It takes as input the JSON object (represented as a Python ``dict``) and, optionally, a build direction and a dictionary of table attributes to customize the generated table:``convert(json_input, build_direction="LEFT_TO_RIGHT", table_attributes=None)``
**Parameters**
json_input : dict
JSON object to convert into HTML.
build_direction : ``{"TOP_TO_BOTTOM", "LEFT_TO_RIGHT"}``, optional
String denoting the build direction of the table. If ``"TOP_TO_BOTTOM"`` child
objects will be appended below parents, i.e. in the subsequent row. If ``"LEFT_TO_RIGHT"``
child objects will be appended to the right of parents, i.e. in the subsequent column.
Default is ``"LEFT_TO_RIGHT"``.table_attributes : ``dict``, optional
Dictionary of ``(key, value)`` pairs describing attributes to add to the table.
Each attribute is added according to the template ``key="value"``. For example,
the table ``{ "border" : 1 }`` modifies the generated table tags to include
``border="1"`` as an attribute. The generated opening tag would look like
````. Default is ``None``.**Returns**
``str``
String of converted HTML.
Installation
------------
The easiest method on installation is to use ``pip``. Simply run:::
>>> pip install json2table
If instead the repo was cloned, navigate to the root directory of the ``json2table`` package from the command line and execute:
::
>>> python setup.py install
Tests
-----In order to verify the code is working, from the command line navigate to the ``json2table`` root directory and run:
::
>>> python -m unittest tests.test_json2table