À quoi sert YAML ?
Un autre format de données texte est YAML ( Yet Another Markup Language ; plus tard, YAML Ain't Markup Language ). Il est utilisé pour sérialiser des objets à transmettre sur le réseau (tout comme XML et JSON sont utilisés de cette façon). Parce qu'il est lisible par l'homme, il est également utilisé pour écrire des fichiers de configuration, par exemple, pour Docker, Kubernetes, Ansible, etc. Lorsque YAML doit être enregistré dans un fichier (par exemple, un fichier de configuration), nous utilisons l'un des deux extensions : .yaml ou .yml.
Syntaxe du langage
En XML, les crochets angulaires ( <> ) sont utilisés pour désigner les balises. En JSON, nous utilisons des accolades ( {} ). YAML utilise de nouvelles lignes et une indentation.
Les données sont stockées sous forme de paires clé-valeur, où la clé est une chaîne et la valeur peut être de différents types de données (chaîne, nombre, vrai/faux, tableau, etc.). Les clés sont écrites sans guillemets.
Voyons comment les informations sont stockées dans YAML :
Taper | Java | YAML |
---|---|---|
Entier |
|
numéro 5
|
Nombre fractionnaire |
|
nombre : 4,3
|
Variable booléenne |
|
valide : faux
valide : non valide : désactivé * Valeurs booléennes valides : vrai/faux, oui/non, activé/désactivé. |
Chaîne |
|
ville : New York
ville : « New York » ville : « New York » * Les trois options sont équivalentes. |
Chaîne avec des caractères spéciaux |
|
ligne : "aaa\nbbb"
|
Commentaire dans le code |
|
# commentaire
|
Objet |
* La classe de l'objet est donnée afin que vous puissiez voir la structure de l'objet. |
personne :
nom : "Dennis" âge : 32 * Faites attention à l'indentation avant les attributs. Il doit être le même pour tous les attributs. |
Liste de valeurs simples |
|
âges : [1, 3,5,9,78, -5]
âges : - 1 - 3 - 5 - 9 - 78 - -5 * Les deux options sont équivalentes. |
Liste des objets |
|
personnes :
- nom : « Ian » âge : 21 ans - nom : « Marina » âge : 25 ans - nom : « Owen » âge : 73 ans |
Comme en Java, un élément d'une liste peut être une liste, c'est-à-dire que les objets peuvent être imbriqués les uns dans les autres. Le trait d'union qui indique l'élément suivant de la liste peut être décalé horizontalement par rapport à la clé parente ou situé directement en dessous de celle-ci. L'essentiel est que tous les éléments aient le même format. Cela aidera à éviter la confusion et une hiérarchie d'imbrication ambiguë.
âges :
- 1 - 3 - 5 - 9 - 78 - -5 |
âges :
- 1 - 3 - 5 - 9 - 78 - -5 |
Il existe deux nuances supplémentaires lorsque vous travaillez avec des valeurs de texte :
-
Texte multiligne. Nous pouvons enregistrer du texte comme ceci :
multilineText : "ligne 1\nligne 2\n....ligne n"Mais il serait très désagréable d'essayer de lire cela. Il y a donc le | (tuyau), que vous pouvez utiliser pour écrire le texte différemment :
texte multiligne : |
ligne 1
ligne 2
....
ligne nVous conviendrez que la seconde option est plus pratique, non ?
-
Longues files d'attente. Si vous souhaitez conserver le texte sur une seule ligne, mais souhaitez également qu'il tienne dans l'espace de travail visible de l'EDI, vous pouvez utiliser le symbole > (supérieur à).
singlelineText : >
début
...
continuer sur la même ligne
...
finTout le texte sera traité comme une seule ligne.
Si vous devez écrire plusieurs structures de données YAML dans un seul fichier, vous devez les séparer par --- (trois traits d'union). En pratique, cela est rarement nécessaire, mais il est préférable d'être conscient de cette possibilité.
Exemple de document YAML
Créons une structure de données Java (une classe) et un objet correspondant, et essayons de représenter l'objet en YAML.
class Family {
private Date weddingDate;
private Person wife;
private Person husband;
private List<Person> children;
// Getters and setters are omitted
}
class Person {
private final String name;
private final boolean isWoman;
private int age;
public Person(String name, int age, boolean isWoman) {
this.name = name;
this.age = age;
this.isWoman = isWoman;
}
// Getters and setters are omitted
}
public static void main(String[] args) {
Person wife = new Person("Ann", 37, true);
Person husband = new Person("Alex", 40, false);
var children = List.of(
new Person("Iris", 12, true),
new Person("Olivia", 5, true)
);
Date weddingDate = new Date(/* some long */);
Family family = new Family();
family.setWeddingDate(weddingDate);
family.setWife(wife);
family.setHusband(husband);
family.setChildren(children);
}
Représentation valide dans YAML :
weddingDate: 2000-12-03
épouse:
nom: Ann
age: 37
isWoman: yes
mari:
name: Alex
age: 40
isWoman: no
children:
- name: Iris
age: 12
isWoman: true
- name: Olivia
age: 5
isWoman: vrai
---
GO TO FULL VERSION