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
Bonjour,
j 'ai un fichier Identite.txt de la forme :
Identite.Nom Identite.Prenom Identite.Age
Redford Robert 56
Eastwood Cleant 80
Deep Johhny 42

Et j'aimerais en lancant la commande cat Identite.txt | script.sh Identite.Nom Identite.Age

qu'il m'affiche les deux colonnes Identite.Nom Identite.Age

Comment puis je faire cela ?

Merci d'avance
A voir également:

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
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 
$ 
0
zalex06 Messages postés 3 Date d'inscription vendredi 8 janvier 2010 Statut Membre Dernière intervention 28 juin 2010
11 janv. 2010 à 11:42
As tu recu mon message privée (jujistsu)
0
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
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
0