YAML

Un article de Wikipédia, l'encyclopédie libre.
Aller à : Navigation, rechercher

YAML, acronyme récursif de YAML Ain't Markup Language, est un format de représentation de données par sérialisation Unicode. Il reprend des concepts d'autres langages comme XML, ou encore du format de message électronique tel que documenté par RFC 2822. YAML a été proposé par Clark Evans en 2001[1], et implémenté par ses soins ainsi que par Brian Ingerson et Oren Ben-Kiki.

Sommaire

Caractéristiques [modifier]

L'idée de fond de YAML est que toute donnée peut être représentée par une combinaison de listes, tableaux (de hachage) et données scalaires. YAML décrit ces formes de données (les représentations YAML), ainsi qu'une syntaxe pour présenter ces données sous la forme d'un flux de caractères (le flux YAML).

Une application informatique passe du flux YAML à la représentation YAML par l'opération de chargement (anglais load). Elle passe de la représentation au flux par l'opération de déchargement (anglais dump).

La syntaxe du flux YAML est relativement simple et efficace, moins verbeuse que du XML, moins compacte que du CSV, et a été établie de sorte qu'elle soit le plus lisible possible par des humains, tout en pouvant être mise en correspondance facilement avec les types de données précités, communs dans les langages de haut niveau. À ces langages il emprunte certaines notations.

  • Les commentaires sont signalés par le signe dièse (#) et se prolongent sur toute la ligne.
  • Une valeur nulle s'écrit avec le caractère tilde (~)
  • Il est possible d'inclure une syntaxe JSON dans une syntaxe YAML.
  • Les items de listes sont dénotés par le tiret (-), suivi d'un espace, à raison d'un item par ligne.
  • Les tableaux sont de la forme clé: valeur, soit à raison d'un couple par ligne.
  • Les scalaires peuvent être entourés de guillemets doubles ("), ou simples ('), ou encore être représentés par un bloc indenté avec des modificateurs facultatifs pour conserver (|) ou éliminer (>) les retours à la ligne.
  • Plusieurs documents rassemblés dans un seul fichier sont séparés par trois traits d'union (---); trois points (...) optionnels marquent la fin d'un document dans un fichier.
  • Les nœuds répétés sont initialement signalés par une esperluette (&) puis sont référencés avec un astérisque (*) ; JSON, un langage concurrent de YAML, est compatible avec la syntaxe de JavaScript mais ne supporte pas cette notion de référence.
  • L'indentation, par des espaces, manifeste une arborescence.
  • Il est possible de préciser le type (anglais Tag) d'une donnée. Cependant, cette précision n'opère aucune contrainte, et fonctionne plutôt comme un marquage, ou une modélisation.
  • Un fichier YAML est analysable en une seule passe de lecture.

La syntaxe YAML se distingue de JSON par le fait qu'il se veut plus facilement lisible par une personne. Il se distingue du XML par le fait qu'il s'intéresse d'abord à la sérialisation de données, et moins à la documentation.

phpMyAdmin permet l'export des bases MySQL en YAML, entre autres formats.

Exemples [modifier]

Listes [modifier]

--- # Films préférés, format bloc
- Casablanca
- Bourgogne Casablanca
- La Règle du jeu
- Titanic
--- # Listes de courses, format linéaire
[lait, pain, œufs]

Tableaux associatifs [modifier]

--- # bloc
nom: Paul Dupond
age: 33
--- # linéaire
{nom: Paul Dupond, age: 33}

Blocs de mise en forme [modifier]

Nouvelles lignes conservées [modifier]

--- |
  There was a young fellow of Warwick
  Who had reason for feeling euphoric
      For he could, by election
      Have triune erection
  Ionic, Corinthian, and Doric

Nouvelles lignes rassemblées [modifier]

--- >
  Le texte ainsi
  séparé sera ensuite
  rassemblé sur
  une seule ligne
  
  Une ligne vide
  signale un nouveau
  paragraphe

Listes de tableaux associatifs [modifier]

- {name: Paul Dupond, age: 33}
-
  name: Marie Dupont
  age: 27

Tableaux de listes [modifier]

homme: [Paul Dupond, Pierre Dubois]
femme:
  - Marie Dupont
  - Susanne Didier

Implémentations [modifier]

Des bibliothèques pour YAML existent pour les langages suivants :

ActionScript
as3yaml Portage de jvyaml pour Actionscript 3.
C++
surcouche C++ de LibYaml.
voir aussi la librairie C++ native yaml-cpp.
D
D:YAML
Erlang
yamler basé sur LibYAML.
Go
goyaml basé sur LibYAML mais réécrit entièrement en Go.
Haskell
YamlReference implémentation de la syntaxe YAML et utilitaires.
yaml encapsulation de LibYAML.
HsSyck interface de SYCK.
json2yaml conversion.
Java
jvyaml basé sur Syck API, et inspiré RbYAML.
JYaml petite impleméntation en Java natif.
SnakeYAML YAML 1.1 pour Java 5.
JavaScript
JS-YAML Réecriture native de PyYAML. Le parseur YAML 1.1+ le lus complet en JS.
CommonJS js-yaml Sous-ensemble réduit de YAML.
javascript-yaml-parser.
jsyaml code on stackoverflow.
Lua
Lua-Syck.
yaml Encapsulation de LibYAML.
.NET Framework
Yaml Library for .NET (C#).
YAML Parser in C# Une implémentation presque complète de YAML. Écrit en C#.
YAML for .NET, Visual Studio and Powershell.
OCaml
OCaml-Syck.
Objective-C
YAML.framework basé sur LibYAML.
syck/ext/cocoa.
Perl
YAML interface vers plusieurs parseurs YAML.
YAML::Tiny implémente un sous-ensemble utilisable de YAML; petit, en Perl pur, et plus rapide que l'implémentation complète.
YAML::Syck Encapsulation de la librairie C SYCK, complète et rapide.
YAML::XS Encapsulation de LibYaml. Meilleure compatibilité YAML 1.1.
YAML::Any Détecte la meilleure implémentation YAML et l'encapsile avec l'API standard YAML.
PHP
Spyc implémentation en pur PHP.
PHP-Syck (encapsulation de la librairie SYCK).
Symfony YAML Component issu du framework Symfony.
PECL Yaml (encapsulation de la librairie LibYAML).
Python
PyYaml Très complète. Python natif ou au choix utilise LibYAML.
PySyck Encapsulation de la librairie SYCK.
Ruby
(YAML est en standard depuis la version 1.8. Basé syr SYCK)
Ya2YAML avec support UTF-8 complet.
ZAML nettement plus rapide que l'implémentation standard.
RbYAML Parseur en Ruby natif.
R
CRAN YAML (encapsulation de la librairie LibYAML).
Scala
scala-yaml.
Tcl
Disponible en Tcl 8.4.
XML
YAXML (non finalisé).

Notes et références [modifier]

  1. YAML Draft 0.1, Clark Evans, 11 Mai 2001, Yahoo! Tech groups: sml-dev

Voir aussi [modifier]

Article connexe [modifier]

Liens externes [modifier]