Script bash - Récupérer des colonnes

Résolu
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention   -  
benit_lbn Messages postés 1 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour à tous,

J'ai débarqué sur la planète bash la semaine dernière :)
Je dois classer des données du style donnee_lieu.txt:
12:56:15:000 25/07/2006 0059,7 09
12:56:51:500 25/09/2006 0062,2 08
12:56:52:000 25/07/2006 0057,7 09
12:56:52:500 25/08/2006 0071,9 09
12:56:08:000 25/07/2006 0065,3 15
12:56:15:000 25/07/2006 0057,7 09
12:56:51:500 25/09/2006 0062,2 08
y'a des tabulations et des espaces pour séparer tout ça.
je dois garder que les codes 08 (à droite), transformer la colonne de gauche en secondes (la on est en HH:MIN:S:MS) et rendre des fichiers traités style donnee_lieu.dat

j'ai embrayé un script, mais c super tendu...
#!/bin/bash
monfich=/home/catto/test.txt
var_monfich='$monfich'
eval cat $var_monfich | awk '{print " " $1 " " $2 " " $3 " " $4 " "}' | grep ' 08 ' | tr ':' ' ' | cut -c2-11,14-25,27-31

ça donne
12 56 51 5 25/09/2006 062,2
12 56 51 5 25/09/2006 062,2
12 56 51 5 26/09/2006 062,2

je bloque complet! et j'ai désespérément besoin d'aide...!
MERCI A TOUS!

13 réponses

gorkimat Messages postés 70 Date d'inscription   Statut Membre Dernière intervention   9
 
Bonjour,

Il y a peut-être plus condensé, mais c'est déjà un début et a adapter.


#!/bin/bash
monfich=MonFic.txt
var_monfich='$monfich'

cat < MonFic.txt | while true
do
read ligne
if [ "$ligne" = "" ]; then break; fi
if [ `echo ${ligne} | awk '{print $4}'` -eq 08 ];
then
heure=`echo ${ligne} | awk '{print $1}' | cut -d: -f1`
minute=`echo ${ligne} | awk '{print $1}' | cut -d: -f2`
seconde=`echo ${ligne} | awk '{print $1}' | cut -d: -f3`
mseconde=`echo ${ligne} | awk '{print $1}' | cut -d: -f4`
# Miliseconde à ajouter
somme=$(($heure*3600+$minute*60+$seconde))
echo "$somme `echo ${ligne} | awk '{print $2 " " $3 " "$4}'`" >> ${monfich}.out
fi
done

Bon courage
0
mounir
 
c bien comme solution , dis moi je connais pas détout le script shell et j'ai envie d'apprendre un peu t'es peu me conseiller d'aller sur que site pour commencer
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention   > mounir
 
quelques sites sympas

http://www.ac-creteil.fr/reseaux/systemes/linux/shell-scripts/filtres.html

http://www.ac-creteil.fr/reseaux/systemes/linux/shell-scripts/shell-programmation.html

http://perso.orange.fr/dorian.linux/bash.html

https://www.linux-pour-lesnuls.com/#introduction
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention  
 
Bonjour!

super merci à gorkimat! t dla balle!

g encore un problème cependant: j'utilise Cygwin /s Win XP et ce dernier ne comprend pas les do, done et les if, fi alors que les syntaxes sont correctes... il me sort syntax error near unexpected token 'done' et même chose pour 'fi' si je supprime le do/done.

un mec a déjà eu ce problème apparemment et il a contacté Cygwin sans réponse en matière j'en ai peur...

voir http://ecos.sourceware.org/ml/cygwin/2001-09/msg00236.html

voila! si jamais vous avez une idée en tête...

MERCI ENCORE!
0
jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention   4 896
 
Salut,

Essaie avec le même script, mais un peu remanié :
#!/bin/bash
monfich=plop.txt

sed -n '/08$/p' $monfich | while true
do
read ligne
if [ "$ligne" = "" ]
then break
fi
col=$(echo ${ligne} | awk '{ print $2 " " $3 " "$4 }')
heure=$(echo ${ligne} | awk -F: '{ print $1 }')
minute=$(echo ${ligne} | awk -F: '{ print $2 }')
seconde=$(echo ${ligne} | awk -F: '{ print $3 }')
mseconde=$(echo ${ligne} | awk -F: '{ print $4 }' | awk '{ print $1 }')
somme="$(($heure*3600+$minute*60+$seconde)),$mseconde"
echo "$somme $col" >> ${monfich}.out
done
N'oublie pas d'ajuster la variable "monfich" avec le nom de ton fichier...

;-))
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention   > jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention  
 
Salut!

Je suis super impressionné par la rapidité de tes réponses: MERCI!

Ton script a l'air nickel en plus.

Ce qui se passe maintenant c'est que Cygwin ne reconnait pas les boucles do et if je comprends pas pkoi...

le fichier trait2 se présente donc comme tu l'as fait:

#!/bin/bash
monfich=/home/catto/test.txt
sed -n '/08$/p' $monfich | while true
do
read ligne
if [ "$ligne" = "" ]
then break
fi
col=$(echo ${ligne} | awk '{ print $2 " " $3 " "$4 }')
heure=$(echo ${ligne} | awk -F: '{ print $1 }')
minute=$(echo ${ligne} | awk -F: '{ print $2 }')
seconde=$(echo ${ligne} | awk -F: '{ print $3 }')
mseconde=$(echo ${ligne} | awk -F: '{ print $4 }' | awk '{ print $1 }')
somme="$(($heure*3600+$minute*60+$seconde)),$mseconde"
echo "$somme $col" >> ${monfich}.out
done


je le lance dans Cygwin par ./trait2 normal

et il me dit:
./trait2: line 16: syntax error near unexpected token 'done'
./trait2: line 16: 'done'

si j'enlève le do et le done il fait pareil mais avec "fi"

Merci une fois encore pour ton aide. Si jamais t'as une idée là-dessus...
0
jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention   4 896
 
Re-

Essaie depuis la ligne de commande et depuis le répertoire où se trouve ton fichier "test.txt", de taper çà :
while read line; do echo "$line" ; done < <(grep "08$" test.txt)
et dis moi ce que ça répond ;-))
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention  
 
salut!

aucun message d'erreur affiché. ça a l'air de marcher

c bon signe?
0
jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention   4 896
 
As-tu eu ça :
12:56:51:500 25/09/2006 0062,2 08
12:56:51:500 25/09/2006 0062,2 08
comme résultat ?
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention   > jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention  
 
non aucun retour écran
le calcul tourne
et j'ai de nouveau la main sous cygwin avec le $
0
jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention   4 896
 
Essaie ça alors :
#!/bin/bash
monfich="/home/catto/test.txt"


sed -n '/08$/p' $monfich > tmp.txt
while read ligne
do
#read ligne
if [ "$ligne" = "" ]
then break
fi
col=$(echo ${ligne} | awk '{ print $2 " " $3 " "$4 }')
heure=$(echo ${ligne} | awk -F: '{ print $1 }')
minute=$(echo ${ligne} | awk -F: '{ print $2 }')
seconde=$(echo ${ligne} | awk -F: '{ print $3 }')
mseconde=$(echo ${ligne} | awk -F: '{ print $4 }' | awk '{ print $1 }')
somme="$(($heure*3600+$minute*60+$seconde)),$mseconde"
echo "$somme $col" >> ${monfich}.out
done < tmp.txt
rm -f tmp.txt

0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention  
 
T es vraiment hallucinant! wao

la g des erreurs (je suis dans le répertoire de test.txt)

$ ./trait2
: No such file or directory
./trait2: line 17: syntax error near unexpected token 'done'
'./trait2: line 17: 'done < tmp.txt

tu penses que ça vient d'où?
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention   4 896
 
Lance ton script en mode débogage, et copie/colle le résultat ici s'il te plait :
sh -xv trait2
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention  
 
$ sh -xv trait2
#!/bin/bash
monfich="/home/catto/test.txt"
+ monfich=$'/home/catto/test.txt\r'
sed -n '/08$/p' $monfich > tmp.txt
+ sed -n '/08$/p' $'monfich > tmp.txt\r'
: No such file or directory
while read ligne
do
#read ligne
if [ "$ligne" = "" ]
then break
fi
col=$(echo ${ligne} | awk '{ print $2 " " $3 " "$4 }')
heure=$(echo ${ligne} | awk -F: '{ print $1 }')
minute=$(echo ${ligne} | awk -F: '{ print $2 }')
seconde=$(echo ${ligne} | awk -F: '{ print $3 }')
mseconde=$(echo ${ligne} | awk -F: '{ print $4 }' | awk '{ print $1 }')
somme="$(($heure*3600+$minute*60+$seconde)),$mseconde"
echo "$somme $col" >> ${monfich}.out
done < tmp.txt
rm -f tmp.txt
trait2: line 17: syntax error near unexpected token 'done'
'rait2: line 17: 'done < tmp.txt

C koi la technique pour copier coller???
0
jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention   4 896
 
y'a un truc qui me chiffonne, c'est l'interprétation de la variable "$monfich" :
monfich="/home/catto/test.txt"
+ monfich=$'/home/catto/test.txt\r'
Dans son interprétation il met un "$" devant alors qu'il ne devrait pas !!!

Essaie de virer la variable dans ton script et met directement le chemin et le nom du fichier en lieu et place, et relance le script en mode débogage.
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention  
 
ça donne ça. ça vient de ma version cygwin?

$ sh -xv trait2
#!/bin/bash
sed -n '/08$/p' test.txt > tmp.txt
+ sed -n '/08$/p' test.txt
: No such file or directory
while read ligne
do
#read ligne
if [ "$ligne" = "" ]
then break
fi
col=$(echo ${ligne} | awk '{ print $2 " " $3 " "$4 }')
heure=$(echo ${ligne} | awk -F: '{ print $1 }')
minute=$(echo ${ligne} | awk -F: '{ print $2 }')
seconde=$(echo ${ligne} | awk -F: '{ print $3 }')
mseconde=$(echo ${ligne} | awk -F: '{ print $4 }' | awk '{ print $1 }')
somme="$(($heure*3600+$minute*60+$seconde)),$mseconde"
echo "$somme $col" >> test.txt.out
done < tmp.txt
trait2: line 16: syntax error near unexpected token 'done'
'rait2: line 16: 'done < tmp.txt
0
jipicy Messages postés 40842 Date d'inscription   Statut Modérateur Dernière intervention   4 896
 
Malheureusement je n'ai pas Cygwin sous la main.
Faudrait attendre que quelqu'un ayant une version d'installée et opérationnelle (comme lami20j) passe dans le coin et essaie ça chez lui pour savoir si effectivement ça vient de ta version ou d'ailleurs...

;-))
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention  
 
franchement t as déjà grave assuré!

merci vraiment.

si jamais tu peux essayer sous cygwin et me dire à l'occas

je vais cloturer ce pb comme résolu et en creer un nouveau plus spécifique

merci encore pour ton aide et ta rapidité!!!!
0
lami20j Messages postés 21331 Date d'inscription   Statut Modérateur, Contributeur sécurité Dernière intervention   3 570
 
Salut à vous,

pas de problèmes pour moi
mais il faut d'abord que j'arrive à la maison :-))
je suis au boulot

à ce soir vers 19h00
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention  
 
salut!

ok ça marche

merci vous êtes super efficaces les gars!
0
lami20j Messages postés 21331 Date d'inscription   Statut Modérateur, Contributeur sécurité Dernière intervention   3 570
 
pour mon amusement je vais voir si je sors une version Perl plus légère ;-)
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention  
 
je connais pas perl

mais si ça permet de traiter des fichiers du type
12:56:15:000 25/07/2006 0059,7 09
12:56:51:500 25/09/2006 0062,2 08
12:56:52:000 25/07/2006 0057,7 09
12:56:52:500 25/08/2006 0071,9 09
12:56:08:000 25/07/2006 0065,3 15
12:56:15:000 25/07/2006 0057,7 09
12:56:51:500 25/09/2006 0062,2 08
12:56:52:000 08/07/2006 0059,7 09
12:56:52:500 25/08/2006 0071,9 09
12:56:08:000 08/07/2006 0065,7 15
12:56:15:000 25/07/2006 0059,6 09
12:56:51:500 26/09/2006 0062,2 08
12:56:52:000 26/07/2006 0052,7 09
08:56:52:500 26/08/2006 0061,3 09
08:56:08:000 26/07/2006 0045,3 15

en très grand nombre et dans les 200000 lignes ça m'intéresse :)
0
lami20j Messages postés 21331 Date d'inscription   Statut Modérateur, Contributeur sécurité Dernière intervention   3 570
 
200000 c'est un jeu d'enfant :-DD

et oui c'est possible, je vais voir ça
0
enzatto Messages postés 16 Date d'inscription   Statut Membre Dernière intervention  
 
ok dla balle alors

l'idée ce serait de donner une ligne de commande suivie du nom du fichier .txt à traiter et le tout renvoyant un fichier du même nom_trai.txt
en gros

merci les gars!!!!! :)
0
benit_lbn Messages postés 1 Date d'inscription   Statut Membre Dernière intervention  
 
j'arrive un peu tard mais ça peut peut-être aider quelqu'un

awk '$4==08 {split($1,tabl,":")
print tabl[1]*3600+tabl[2]*60+tabl[3]+tabl[4]/1000 ,$2 , $3, $4}' donnee_lieu.txt > resultat.txt


parce que franchement les scripts plus haut c'est ce compliquer la vie
0