# YTE - A YAML template engine with Python expressions
[![Docs](https://img.shields.io/badge/user-documentation-green)](https://yte-template-engine.github.io)
[![test coverage: 100%](https://img.shields.io/badge/test%20coverage-100%25-green)](https://github.com/yte-template-engine/yte/blob/main/pyproject.toml#L30)
![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/yte-template-engine/yte/testing.yml?branch=main)
![PyPI](https://img.shields.io/pypi/v/yte)
[![Conda Recipe](https://img.shields.io/badge/recipe-yte-green.svg)](https://anaconda.org/conda-forge/yte)
[![Conda Downloads](https://img.shields.io/conda/dn/conda-forge/yte.svg)](https://anaconda.org/conda-forge/yte)
[![Conda Version](https://img.shields.io/conda/vn/conda-forge/yte.svg)](https://github.com/conda-forge/yte-feedstock)
YTE is a template engine for YAML format that utilizes the YAML structure in combination with Python expressions for enabling to dynamically build YAML documents.
The key idea of YTE is to rely on the YAML structure to enable conditionals, loops and other arbitrary Python expressions to dynamically render YAML files.
Python expressions are thereby declared by prepending them with a `?` anywhere in the YAML.
Any such value will be automatically evaluated by YTE, yielding plain YAML as a result.
Importantly, YTE templates are still valid YAML files (for YAML, the `?` expressions are just strings).
Documentation of YTE can be found at https://yte-template-engine.github.io.
## Comparison with other engines
Lots of template engines are available, for example the famous generic [jinja2](https://jinja.palletsprojects.com).
The reasons to generate a YAML specific engine are
1. The YAML syntax can be exploited to simplify template expression syntax, and make it feel less foreign (i.e. fewer special characters for control flow needed) while increasing human readability.
2. Whitespace handling (which is important with YAML since it has a semantic there) becomes unnecessary (e.g. with jinja2, some [tuning](https://radeksprta.eu/posts/control-whitespace-in-ansible-templates) is required to obtain proper YAML rendering).
Of course, YTE is not the first YAML specific template engine.
Others include
* [Yglu](https://yglu.io)
* [Emrichen](https://github.com/con2/emrichen)
The main difference between YTE and these two is that YTE extends YAML with plain Python syntax instead of introducing another specialized language.
Of course, the choice is also a matter of taste.
Raw data
{
"_id": null,
"home_page": "https://github.com/yte-template-engine/yte",
"name": "yte",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": null,
"keywords": null,
"author": "Johannes K\u00f6ster",
"author_email": "johannes.koester@tu-dortmund.de",
"download_url": "https://files.pythonhosted.org/packages/78/fb/b29e57ea7466423796882b363f3b257fb2b084f4ccadd37f211113ffbd79/yte-1.5.5.tar.gz",
"platform": null,
"description": "# YTE - A YAML template engine with Python expressions\n\n[![Docs](https://img.shields.io/badge/user-documentation-green)](https://yte-template-engine.github.io)\n[![test coverage: 100%](https://img.shields.io/badge/test%20coverage-100%25-green)](https://github.com/yte-template-engine/yte/blob/main/pyproject.toml#L30)\n![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/yte-template-engine/yte/testing.yml?branch=main)\n![PyPI](https://img.shields.io/pypi/v/yte)\n[![Conda Recipe](https://img.shields.io/badge/recipe-yte-green.svg)](https://anaconda.org/conda-forge/yte)\n[![Conda Downloads](https://img.shields.io/conda/dn/conda-forge/yte.svg)](https://anaconda.org/conda-forge/yte)\n[![Conda Version](https://img.shields.io/conda/vn/conda-forge/yte.svg)](https://github.com/conda-forge/yte-feedstock)\n\n\nYTE is a template engine for YAML format that utilizes the YAML structure in combination with Python expressions for enabling to dynamically build YAML documents.\n\nThe key idea of YTE is to rely on the YAML structure to enable conditionals, loops and other arbitrary Python expressions to dynamically render YAML files.\nPython expressions are thereby declared by prepending them with a `?` anywhere in the YAML.\nAny such value will be automatically evaluated by YTE, yielding plain YAML as a result.\nImportantly, YTE templates are still valid YAML files (for YAML, the `?` expressions are just strings).\n\nDocumentation of YTE can be found at https://yte-template-engine.github.io.\n\n## Comparison with other engines\n\nLots of template engines are available, for example the famous generic [jinja2](https://jinja.palletsprojects.com).\nThe reasons to generate a YAML specific engine are\n\n1. The YAML syntax can be exploited to simplify template expression syntax, and make it feel less foreign (i.e. fewer special characters for control flow needed) while increasing human readability.\n2. Whitespace handling (which is important with YAML since it has a semantic there) becomes unnecessary (e.g. with jinja2, some [tuning](https://radeksprta.eu/posts/control-whitespace-in-ansible-templates) is required to obtain proper YAML rendering).\n\nOf course, YTE is not the first YAML specific template engine.\nOthers include\n\n* [Yglu](https://yglu.io)\n* [Emrichen](https://github.com/con2/emrichen)\n\nThe main difference between YTE and these two is that YTE extends YAML with plain Python syntax instead of introducing another specialized language.\nOf course, the choice is also a matter of taste.\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A YAML template engine with Python expressions",
"version": "1.5.5",
"project_urls": {
"Homepage": "https://github.com/yte-template-engine/yte",
"Repository": "https://github.com/yte-template-engine/yte"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "e42a2cc9ef5b64369445eba774bef3fd9e0950cdf4998ec6b6fb06dba4c43ca5",
"md5": "d1c8700615b8ccf87383891f1a22fec0",
"sha256": "e4de66359566cc671ecd134637964b816c4681f4d03673de0d91608abfb0e079"
},
"downloads": -1,
"filename": "yte-1.5.5-py3-none-any.whl",
"has_sig": false,
"md5_digest": "d1c8700615b8ccf87383891f1a22fec0",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7",
"size": 7827,
"upload_time": "2024-12-09T16:51:13",
"upload_time_iso_8601": "2024-12-09T16:51:13.898025Z",
"url": "https://files.pythonhosted.org/packages/e4/2a/2cc9ef5b64369445eba774bef3fd9e0950cdf4998ec6b6fb06dba4c43ca5/yte-1.5.5-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "78fbb29e57ea7466423796882b363f3b257fb2b084f4ccadd37f211113ffbd79",
"md5": "05566782e621a90bc2d2e9b2dbefcf15",
"sha256": "2c49831859f3216f313a17688900690872e05f8fbe77cb5d151bdb896357d57e"
},
"downloads": -1,
"filename": "yte-1.5.5.tar.gz",
"has_sig": false,
"md5_digest": "05566782e621a90bc2d2e9b2dbefcf15",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 6506,
"upload_time": "2024-12-09T16:51:15",
"upload_time_iso_8601": "2024-12-09T16:51:15.451136Z",
"url": "https://files.pythonhosted.org/packages/78/fb/b29e57ea7466423796882b363f3b257fb2b084f4ccadd37f211113ffbd79/yte-1.5.5.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-09 16:51:15",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "yte-template-engine",
"github_project": "yte",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "yte"
}