1
0
Fork 0
mirror of https://github.com/adrienverge/yamllint.git synced 2026-01-08 15:57:12 +01:00
A linter for YAML files.
Find a file
Adrien Vergé 73b9c0b542 Drop support for Python 3.9
Python 3.9 is officially "end-of-life" since 2025-10-31.

Note: Python 3.14 is officially supported since commit 823a96e "CI: Test
more versions of Python".
2025-12-03 08:38:01 +01:00
.github/workflows Drop support for Python 3.9 2025-12-03 08:38:01 +01:00
docs README: Add Alpine Linux installation instructions 2025-11-13 08:52:11 +01:00
tests Drop support for Python 3.9 2025-12-03 08:38:01 +01:00
yamllint indentation: Fix error message for check-multi-line-strings 2025-11-13 11:23:54 +01:00
.flake8 Revert replacement of flake8 with ruff 2024-02-02 10:05:14 +01:00
.gitignore gitignore: Add /.eggs 2020-09-27 10:06:33 +02:00
.pre-commit-hooks.yaml pre-commit is now served over https! 2018-03-03 08:01:24 +01:00
.readthedocs.yaml build: Restore official Read the Docs theme 2024-02-06 15:54:53 +01:00
CHANGELOG.rst yamllint version 1.37.1 2025-05-04 10:24:35 +02:00
CONTRIBUTING.rst Revert replacement of flake8 with ruff 2024-02-02 10:05:14 +01:00
LICENSE License: Update to latest version of GPLv3 2022-08-06 15:14:57 +02:00
MANIFEST.in build: Restore documentation and test files in sdist 2025-03-17 08:59:44 +01:00
pyproject.toml Drop support for Python 3.9 2025-12-03 08:38:01 +01:00
README.rst README: Enhance wording of recursive directory lint 2025-11-13 08:49:38 +01:00

yamllint
========

A linter for YAML files.

yamllint does not only check for syntax validity, but for weirdnesses like key
repetition and cosmetic problems such as lines length, trailing spaces,
indentation, etc.

.. image::
   https://github.com/adrienverge/yamllint/actions/workflows/tests.yaml/badge.svg?branch=master
   :target: https://github.com/adrienverge/yamllint/actions/workflows/tests.yaml?query=branch%3Amaster
   :alt: CI tests status
.. image::
   https://coveralls.io/repos/github/adrienverge/yamllint/badge.svg?branch=master
   :target: https://coveralls.io/github/adrienverge/yamllint?branch=master
   :alt: Code coverage status
.. image:: https://readthedocs.org/projects/yamllint/badge/?version=latest
   :target: https://yamllint.readthedocs.io/en/latest/?badge=latest
   :alt: Documentation status

Written in Python.

Documentation
-------------

https://yamllint.readthedocs.io/

Overview
--------

Screenshot
^^^^^^^^^^

.. image:: docs/screenshot.png
   :alt: yamllint screenshot

Installation
^^^^^^^^^^^^

Using pip, the Python package manager:

.. code:: bash

 pip install --user yamllint

yamllint is also packaged for all major operating systems, see installation
examples (``dnf``, ``apt-get``...) `in the documentation
<https://yamllint.readthedocs.io/en/stable/quickstart.html>`_.

Usage
^^^^^

.. code:: bash

 # Lint one or more files
 yamllint my_file.yml my_other_file.yaml ...

.. code:: bash

 # Recursively lint all YAML files in a directory
 yamllint .

.. code:: bash

 # Use a pre-defined lint configuration
 yamllint -d relaxed file.yaml

 # Use a custom lint configuration
 yamllint -c /path/to/myconfig file-to-lint.yaml

.. code:: bash

 # Output a parsable format (for syntax checking in editors like Vim, emacs...)
 yamllint -f parsable file.yaml

`Read more in the complete documentation! <https://yamllint.readthedocs.io/>`__

Features
^^^^^^^^

Here is a yamllint configuration file example:

.. code:: yaml

 extends: default

 rules:
   # 80 chars should be enough, but don't fail if a line is longer
   line-length:
     max: 80
     level: warning

   # don't bother me with this rule
   indentation: disable

Within a YAML file, special comments can be used to disable checks for a single
line:

.. code:: yaml

 This line is waaaaaaaaaay too long  # yamllint disable-line

or for a whole block:

.. code:: yaml

 # yamllint disable rule:colons
 - Lorem       : ipsum
   dolor       : sit amet,
   consectetur : adipiscing elit
 # yamllint enable

Specific files can be ignored (totally or for some rules only) using a
``.gitignore``-style pattern:

.. code:: yaml

 # For all rules
 ignore: |
   *.dont-lint-me.yaml
   /bin/
   !/bin/*.lint-me-anyway.yaml

 rules:
   key-duplicates:
     ignore: |
       generated
       *.template.yaml
   trailing-spaces:
     ignore: |
       *.ignore-trailing-spaces.yaml
       /ascii-art/*

`Read more in the complete documentation! <https://yamllint.readthedocs.io/>`__

License
-------

`GPL version 3 <LICENSE>`_