Voici un analyseur basé sur bash qui utilise sed et awk pour analyser des fichiers yaml simples :
function parse_yaml {
local prefix=$2
local s='[[:space:]]*' w='[a-zA-Z0-9_]*' fs=$(echo @|tr @ '\034')
sed -ne "s|^\($s\):|\1|" \
-e "s|^\($s\)\($w\)$s:$s[\"']\(.*\)[\"']$s\$|\1$fs\2$fs\3|p" \
-e "s|^\($s\)\($w\)$s:$s\(.*\)$s\$|\1$fs\2$fs\3|p" $1 |
awk -F$fs '{
indent = length($1)/2;
vname[indent] = $2;
for (i in vname) {if (i > indent) {delete vname[i]}}
if (length($3) > 0) {
vn=""; for (i=0; i
`Il comprend des fichiers tels que :
## définitions globales
global:
debug: yes
verbose: no
debugging:
detailed: no
header: "debugging started"
## sortie
output:
file: "yes"
Qui, lorsqu'il est analysé avec :
parse_yaml sample.yml
donnera en sortie :
global_debug="yes"
global_verbose="no"
global_debugging_detailed="no"
global_debugging_header="debugging started"
output_file="yes"
Il comprend également des fichiers yaml générés par ruby qui peuvent inclure des symboles ruby, comme :
---
:global:
:debug: 'yes'
:verbose: 'no'
:debugging:
:detailed: 'no'
:header: debugging started
:output: 'yes'
et donnera le même résultat que dans l'exemple précédent.
Une utilisation classique dans un script est la suivante :
eval $(parse_yaml sample.yml)
parse_yaml accepte un argument de préfixe afin que toutes les configurations importées aient un préfixe commun (ce qui réduira les risques de collisions de noms).
parse_yaml sample.yml "CONF_"
donne :
CONF_global_debug="yes"
CONF_global_verbose="no"
CONF_global_debugging_detailed="no"
CONF_global_debugging_header="debugging started"
CONF_output_file="yes"
Remarquez que les configurations précédentes dans un fichier peuvent être référencées par les configurations ultérieures :
## définitions globales
global:
debug: yes
verbose: no
debugging:
detailed: no
header: "debugging started"
## sortie
output:
debug: $global_debug
Une autre utilisation intéressante est de d'abord analyser un fichier de valeurs par défaut puis les paramètres de l'utilisateur, ce qui fonctionne puisque les paramètres ultérieurs remplacent les premiers :
eval $(parse_yaml defaults.yml)
eval $(parse_yaml project.yml)`
0 votes
Pas directement votre question, mais vous voudrez peut-être jeter un œil à ansible si votre script shell concerne particulièrement la gestion à distance de différents nœuds (et un inventaire yaml)
20 votes
Essayez d'utiliser
yq
pour lire/écrire des fichiers yaml dans le shell. La page du projet est ici: mikefarah.github.io/yq Vous pouvez installer l'outil avecbrew
,apt
ou télécharger le binaire. Lire une valeur est aussi simple queyq r some.yaml key.value
0 votes
@kenorb JSON != yml/YAML
1 votes
J'ai trouvé des fonctions étroitement liées sur github de pkuczynski parmi lesquelles la meilleure (pour moi) était celle de jasperes, maintenue dans son propre github
0 votes
@swe en fait
json == yaml
maisyaml != json
. Cela signifie que yaml est un superset de json.