Programmation.shell : commande Cat avec un arret prècis
Posté par dubis () le 31 mars 2008Bonjour,
Est-il possible de faire un "cat" ou "more" d'un fichier avec un arrêt précis qui correspond à une date. Dans mon cas, c'est "TIMESTAMP 12/31/2007".
Merci de votre aide.
> Lire le message (16 commentaires, moyenne: 3).
Vous avez demandé le commentaire #917916.



Réponse alambiquée :
$ tail -n `echo $(($(wc -l fichier.txt | cut -f 1 -d ' ') - $(grep -n "TIMESTAMP 12/31/2007" fichier.txt | cut -f 1 -d ':') + 1))` fichier.txt
Quelques explications :
On recherche le nombre de lignes du fichier fichier.txt (wc -l) et on ne récupère que le nombre de ligne (cut -f 1 -d ' ').
On y retranche le numéro de la ligne où l'on trouve le motif (grep -n "TIMESTAMP 12/31/2007" (là encore, on ne récupère que le numéro de la ligne, et pas tout le blabla qui s'en suit (cut -f 1 -d ':').
On effectue la soustraction des deux grâce au echo $((A -B +1))
Enfin, on appel tail -n resultat fichier.txt
Voilà, j'espère que ceci répond à la question.
Il y a probablement plus simple, mais au moins, cette commande fonctionne.
All articles which are excluded shall be deemed included
Tous les articles exclus sont considérés inclus
--Brian de Palma in Phantom of the Paradize
[^]Re: Réponse alambiquée :
Merci Gyro
Effectivement je n'avait pas penser à la commande "tail" certainement à cause du lundi matin :-)
J'ai simplifié ta ligne de commande par la suivante :
tail -`grep -n "TIMESTAMP 12/31/2007" Fichier.log | awk -F: '{print $1}'` Fichier.log
Mais j'ai un problème avec celle ci. En effet la commande tail -34 Fichier.log m'affiche bien les premières 34 lignes du fichier.log.
Dans mon cas le "grep -n "TIMESTAMP 12/31/2007" Fichier.log | awk -F: '{print $1}'" donne 34171. Le tail m'affiche tout le fichier sans s'arrêter à la ligne 34171.
Merci de votre aide
[^]Re: Réponse alambiquée :
C'est une question de sens, à mon avis....
Si le but est d'afficher les 37141 dernières lignes, il faut en effet utiliser tail, mais si le but est d'afficher les 37141 premières lignes, il faudrait peut-être utiliser head...
Autrement, pour afficher un intervalle, par exemple de la ligne 31542 à la ligne 37141, il faudrait coupler les deux...
Commencer par un head, par exemple, du début du fichier à la ligne 37141, et passer le résultat (que ce soit un pipe ou un fichier temporaire ne changera rien à l'affaire) à tail...
Voilà, en espérant que ça aide.
All articles which are excluded shall be deemed included
Tous les articles exclus sont considérés inclus
--Brian de Palma in Phantom of the Paradize
[^]Re: Réponse alambiquée :
awk ' { if ( $0~/TIMESTAMP 12\/31\/2007/ ) { exit }; print $0 }' toto2.txt
[^]Re: Réponse alambiquée :
C'est quand même plus simple que vos cat | head|cut ...
[^]Re: Réponse alambiquée :
Oui, mais t'es sûr que ça répond au problème ? ;)
(en fait, ça s'arrête 1 ligne trop tôt - mais il y a peut-être une solution simple)
[^]Re: Réponse alambiquée :
(en fait, ça s'arrête 1 ligne trop tôt - mais il y a peut-être une solution simple)
--> solution toute simple: imprimer AVANTde quiter:
awk ' { print $0; if ( $0~/mon texte/ ) { exit } }' monfichier.txt
:-)
[^]Re: Réponse alambiquée :
J'etais pas sur qu'il fallait afficher la ligne en question, mais ce que j'ai donné en solution servait juste de base de travail, et était simplement modifiable.
[^]Re: Réponse alambiquée :
La même chose et simplement pour gagner quelques caractères :
awk '/TIMESTAMP 12\/31\/2007/{print; exit;} {print;}'En effet, avec awk /pattern/{ code;} exécute le code du bloque si la ligne correspond au pattern.
De même print $0; peut s'abréger en print;
Par rapport à la version en sed, c'est vrai que awk est un peu plus clair, sed ayant des commandes très abrégées.
Étienne