informatique:awk
Différences
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédenteDernière révisionLes deux révisions suivantes | ||
informatique:awk [2019/03/21 08:57] – alexis | informatique:awk [2022/09/29 03:07] – alexis | ||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
====== Awk ====== | ====== Awk ====== | ||
- | <WRAP center round todo 60%> | + | ===== Variables ===== |
- | cat var/ | + | |
- | 440 credit_notes | + | |
- | 7 deposits | + | |
- | 3 direct_debit_batches | + | |
- | 909 incidents | + | |
- | 26378 invoices | + | |
- | 78 operations | + | |
- | 11201 payments | + | |
- | 145 refunds | + | |
- | 81 safe_deposits | + | |
- | cat var/ | + | === FILENAME — nom du fichier courant === |
- | 39242 | + | La variable |
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | awk ' | ||
+ | </ | ||
</ | </ | ||
+ | === FNR — nombre d' | ||
+ | La variable '' | ||
+ | Le compteur d' | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | awk ' | ||
+ | </ | ||
+ | </ | ||
- | ===== Variables | + | === FS — Séparateur de champs |
- | * NR : nombre d' | + | La variable '' |
- | * FNR : nombre d' | + | Par défaut, l' |
- | * FILENAME : nom du fichier | + | <WRAP prewrap> |
- | * FS : séparateur | + | <code bash> |
- | | + | # Initialisation de la variable dans la liste de commande |
+ | awk 'BEGIN { FS="=" } { print $1 }' < | ||
+ | |||
+ | # Initialisation de la variable par l' | ||
+ | awk -F'=' ' | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | <WRAP info> | ||
+ | Le séparateur de champ peut être une expression rationnelle. | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | # Initialisation de la variable dans la liste de commande | ||
+ | awk 'BEGIN { FS=" | ||
+ | |||
+ | # Initialisation de la variable par l' | ||
+ | awk -F' | ||
+ | </ | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | |||
+ | === NF — Nombre de champs === | ||
+ | La variable '' | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | awk ' | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | === NR — Nombre | ||
+ | La variable '' | ||
+ | Le compteur d' | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | awk ' | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | === OFS — Séparateur | ||
+ | La variable '' | ||
+ | Par défaut, l' | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | awk 'BEGIN { OFS=":" | ||
+ | </ | ||
+ | </ | ||
===== Scripts ===== | ===== Scripts ===== | ||
==== Remplacer les clefs par les valeurs ==== | ==== Remplacer les clefs par les valeurs ==== | ||
+ | <WRAP prewrap> | ||
<code awk> | <code awk> | ||
# fichier_1 contient l' | # fichier_1 contient l' | ||
Ligne 46: | Ligne 95: | ||
# ID4 30 | # ID4 30 | ||
</ | </ | ||
+ | </ | ||
* '' | * '' | ||
* '' | * '' | ||
Ligne 52: | Ligne 102: | ||
==== Afficher la date courante ==== | ==== Afficher la date courante ==== | ||
+ | <WRAP prewrap> | ||
<code awk> | <code awk> | ||
awk '{ "date +%d-%b-%Y" | awk '{ "date +%d-%b-%Y" | ||
</ | </ | ||
+ | </ | ||
* '' | * '' | ||
* '' | * '' | ||
Ligne 61: | Ligne 112: | ||
==== Afficher toutes les trois lignes d'un fichier ==== | ==== Afficher toutes les trois lignes d'un fichier ==== | ||
* En commençant à la première ligne | * En commençant à la première ligne | ||
+ | <WRAP prewrap> | ||
<code awk> | <code awk> | ||
awk '(NR%3 == 1){print $0}' | awk '(NR%3 == 1){print $0}' | ||
</ | </ | ||
+ | </ | ||
* En commençant à la deuxième ligne | * En commençant à la deuxième ligne | ||
+ | <WRAP prewrap> | ||
<code awk> | <code awk> | ||
awk '(NR%3 == 2){print $0}' | awk '(NR%3 == 2){print $0}' | ||
</ | </ | ||
+ | </ | ||
* En commençant à la troisième ligne | * En commençant à la troisième ligne | ||
+ | <WRAP prewrap> | ||
<code awk> | <code awk> | ||
awk '(NR%3 == 0){print $0}' | awk '(NR%3 == 0){print $0}' | ||
Ligne 75: | Ligne 131: | ||
awk ' | awk ' | ||
</ | </ | ||
+ | </ | ||
+ | |||
+ | ==== Faire des statistiques d' | ||
+ | |||
+ | Dans le journal des évènements d'une API contenant la liste des URI appelées, je veux compter les types d' | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | # trouver le nombre d' | ||
+ | cat / | ||
+ | |||
+ | # Résultat obtenu | ||
+ | 440 credit_notes | ||
+ | 7 deposits | ||
+ | 3 direct_debit_batches | ||
+ | 909 incidents | ||
+ | 26378 invoices | ||
+ | 78 operations | ||
+ | 11201 payments | ||
+ | 145 refunds | ||
+ | 81 safe_deposits | ||
+ | |||
+ | # Trouver le nombre d' | ||
+ | cat / | ||
+ | # Mais c'est beaucoup plus simple d' | ||
+ | wc -l / | ||
+ | |||
+ | # Résultat obtenu | ||
+ | 39242 | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== Afficher le dernier champ de chaque ligne ==== | ||
+ | En faisant astucieusement usage de la variable '' | ||
+ | )) | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | awk ' | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | ==== Remplacer le séparateur d'un fichier ==== | ||
+ | En assignant la variable '' | ||
+ | La reconstruction de l' | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | # Ici, 1 équivaut à true, ce qui affiche la ligne complète | ||
+ | awk 'BEGIN { FS=","; | ||
+ | |||
+ | # Cette écriture est donc équivalente | ||
+ | awk 'BEGIN { FS=","; | ||
+ | </ | ||
+ | </ | ||
===== Liens ===== | ===== Liens ===== |
informatique/awk.txt · Dernière modification : 2023/01/04 20:46 de alexis