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 [2020/07/02 23:56] – [Afficher toutes les trois lignes d'un fichier] alexis | informatique:awk [2022/09/29 03:07] – alexis | ||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
====== Awk ====== | ====== Awk ====== | ||
- | <WRAP todo> | + | ===== Variables ===== |
- | <code bash>cat var/ | + | |
- | 440 credit_notes | + | === FILENAME — nom du fichier courant === |
- | 7 deposits | + | La variable '' |
- | 3 direct_debit_batches | + | <WRAP prewrap> |
- | 909 incidents | + | <code bash> |
- | 26378 invoices | + | awk ' |
- | 78 operations | + | </ |
- | 11201 payments | + | </ |
- | 145 refunds | + | |
- | 81 safe_deposits | + | |
- | <code bash>cat var/ | + | === FNR — nombre d' |
+ | La variable '' | ||
+ | Le compteur d' | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | awk ' | ||
+ | </code> | ||
+ | </WRAP> | ||
- | 39242 | + | === FS — Séparateur de champs === |
+ | La variable '' | ||
+ | Par défaut, l' | ||
+ | <WRAP prewrap> | ||
+ | <code bash> | ||
+ | # Initialisation de la variable dans la liste de commande | ||
+ | awk 'BEGIN { FS=" | ||
+ | |||
+ | # 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=" | ||
- | ===== Variables | + | # Initialisation de la variable par l' |
- | * NR : nombre | + | awk -F'[=_]' ' |
- | * FNR : nombre d' | + | </ |
- | * FILENAME : nom du fichier | + | </ |
- | * FS : séparateur | + | </ |
- | | + | |
+ | |||
+ | === 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 48: | Ligne 95: | ||
# ID4 30 | # ID4 30 | ||
</ | </ | ||
+ | </ | ||
* '' | * '' | ||
* '' | * '' | ||
Ligne 54: | 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 63: | 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 77: | Ligne 131: | ||
awk ' | awk ' | ||
</ | </ | ||
+ | </ | ||
==== Faire des statistiques d' | ==== 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' | 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> | <code bash> | ||
# trouver le nombre d' | # trouver le nombre d' | ||
Ligne 104: | Ligne 160: | ||
39242 | 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 ===== | ||
* [[http:// | * [[http:// |
informatique/awk.txt · Dernière modification : 2023/01/04 20:46 de alexis