Selection d'une colonne en bash
Fermé
jujitsu
-
6 janv. 2010 à 17:30
dubcek Messages postés 18755 Date d'inscription lundi 15 janvier 2007 Statut Contributeur Dernière intervention 14 novembre 2024 - 12 janv. 2010 à 09:11
dubcek Messages postés 18755 Date d'inscription lundi 15 janvier 2007 Statut Contributeur Dernière intervention 14 novembre 2024 - 12 janv. 2010 à 09:11
A voir également:
- Selection d'une colonne en bash
- Déplacer une colonne excel - Guide
- Formule somme excel colonne - Guide
- Trier colonne excel - Guide
- Colonne word - Guide
- Figer une colonne excel - Guide
2 réponses
dubcek
Messages postés
18755
Date d'inscription
lundi 15 janvier 2007
Statut
Contributeur
Dernière intervention
14 novembre 2024
5 621
7 janv. 2010 à 10:30
7 janv. 2010 à 10:30
hello
$ cat a3 Identite.Nom Identite.Prenom Identite.Age Redford Robert 56 Eastwood Cleant 80 Deep Johhny 42 $ $ cat f9 #!/bin/bash awk 'NR==1{nfy=split(arg,y);nfx=split($0,x);for(i=1;i<=nfx;i++){xx[x[i]]=i};next};{for(n=1;n<=nfy;n++)printf("%s ", $(xx[y[n]]));print ""}' arg="$*" $ $ cat a3 | ./f9 Identite.Nom Identite.Age Redford 56 Eastwood 80 Deep 42 $ $ cat a3 | ./f9 Identite.Nom Identite.Age Identite.Prenom Redford 56 Robert Eastwood 80 Cleant Deep 42 Johhny $ $ cat a3 | ./f9 Identite.Age 56 80 42 $
dubcek
Messages postés
18755
Date d'inscription
lundi 15 janvier 2007
Statut
Contributeur
Dernière intervention
14 novembre 2024
5 621
12 janv. 2010 à 09:11
12 janv. 2010 à 09:11
problèmes : le nombre de colonnes à afficher est variable et awk a besoin du No de la colonne
NR==1 : on ne traite que la ligne 1
nfy=split(arg,y) : on stocke chaque argument ($*) dans un tableau y, nfy est leur nombre
nfx=split($0,x) : on stocke chaque nom de colonne dans un tableau x, nfx est leur nombre
for(i=1;i<=nfx;i++){xx[x[i]]=i} : on stocke dans un tableau xx le No de chaque colonne en utilisant son nom, qui est dans x, comme index, on a donc xx[nom de la colonne]=No de la colonne
next : on lit la suite
ensuite pour chaque ligne:
for(n=1;n<=nfy;n++)printf("%s ", $(xx[y[n]])) : on imprime chaque colonne par son numéro, contenu dans xx, dont le nom est dans y : $(xx[nom de la colonne]
print "" : et un saut de ligne à chaque fin de ligne
NR==1 : on ne traite que la ligne 1
nfy=split(arg,y) : on stocke chaque argument ($*) dans un tableau y, nfy est leur nombre
nfx=split($0,x) : on stocke chaque nom de colonne dans un tableau x, nfx est leur nombre
for(i=1;i<=nfx;i++){xx[x[i]]=i} : on stocke dans un tableau xx le No de chaque colonne en utilisant son nom, qui est dans x, comme index, on a donc xx[nom de la colonne]=No de la colonne
next : on lit la suite
ensuite pour chaque ligne:
for(n=1;n<=nfy;n++)printf("%s ", $(xx[y[n]])) : on imprime chaque colonne par son numéro, contenu dans xx, dont le nom est dans y : $(xx[nom de la colonne]
print "" : et un saut de ligne à chaque fin de ligne
11 janv. 2010 à 11:42