IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Shell et commandes GNU Discussion :

AWK - transformer un fichier en tableau


Sujet :

Shell et commandes GNU

  1. #1
    Membre averti
    Inscrit en
    Décembre 2006
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 42
    Par défaut AWK - transformer un fichier en tableau
    Bonjour à tous,

    Je ne savais pas trop où poster ma question, j'espère ne pas trop être hors sujet ici...

    Voilà, je débute en awk, et j'essaye de récupérer certaines infos d'un fichier dans un autre.
    Pour cela, j'ai besoin de traiter ce fichier comme un tableau (de type matrice), et je n'arrive pas à trouver comment faire, j'ai essayé l'instruction "SUBSET" en vain...
    Quelqu'un pourrait-il m'aider svp ?

    Voici l'illustration de mon problème, j'ai un fichier ainsi constitué :

    champs1 champs2
    champs3
    champs4 champs5 champs6
    ...etc

    Je veux faire un test : si champs3==1
    alors nouveaufichier=champs2 champs3 champs6

    Par exemple, comment faire svp ?
    Merci d'avance

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 102
    Par défaut
    Citation Envoyé par pcappell Voir le message
    Bonjour à tous,

    Je ne savais pas trop où poster ma question, j'espère ne pas trop être hors sujet ici...

    Voilà, je débute en awk, et j'essaye de récupérer certaines infos d'un fichier dans un autre.
    Pour cela, j'ai besoin de traiter ce fichier comme un tableau (de type matrice), et je n'arrive pas à trouver comment faire, j'ai essayé l'instruction "SUBSET" en vain...
    Quelqu'un pourrait-il m'aider svp ?

    Voici l'illustration de mon problème, j'ai un fichier ainsi constitué :

    champs1 champs2
    champs3
    champs4 champs5 champs6
    ...etc

    Je veux faire un test : si champs3==1
    alors nouveaufichier=champs2 champs3 champs6

    Par exemple, comment faire svp ?
    Merci d'avance
    Bonjour,

    d'après ce que tu dis, ton fichier contient 2 champs sur la 1ère ligne, 1 sur la 2ème et 3 sur la 3ème.
    Et tu voudrais tester l'unique champ de la 2ème ligne et s'il vaut 1 alors retourner le 2ème champ de la 1ère ligne, le 1er champ de la 2ème et le 3ème de la 3ème.
    C'est bien cela que tu veux faire?

    )jack(

  3. #3
    Membre averti
    Inscrit en
    Décembre 2006
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 42
    Par défaut
    Bonjour,

    Oui c'est bien cela, sauf que mon fichier est beaucoup plus grand et contient beaucoup plus de blocs de champs présentés à peu près comme dans mon exemple précédent.

    C'est pourquoi pour faire un test sur certains champs de certaines lignes et récupérer des champs des lignes précédentes et des lignes suivantes par rapport à ma ligne courante je pense que traiter mon fichier façon matrice sera plus simple pour faire des boucles dessus.

    Je vais mettre un extrait exact de mon fichier en exemple ce sera peut-être plus simple :

    " REDRESSEMENT 1 (15 ANS ET + MIXTE) :
    Converge

    Efficacité du redressement : 91.8 %
    Poids Maximum : 2.733813
    Poids Minimum : 0.369164


    REDRESSEMENT 2 (18 ANS ET + MIXTE) :
    Ne Converge

    Efficacité du redressement : 93.7 %
    Poids Maximum : 2.419821
    Poids Minimum : 0.399674
    ... etc"

    si le redressement converge je veux écrire dans un autre fichier :
    "REDRESSEMENT 1 converge
    Efficacité : 91.8%"

    Et si le redressement ne converge pas je veux remplacer ce redressement par un autre contenu un peu plus loin dans mon fichier en entrée.

    Merci d'avance pour toute aide ou suggestion !!!

  4. #4
    Membre émérite Avatar de BlaireauOne
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    492
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2007
    Messages : 492
    Par défaut
    Ça semble le faire sans passer par une table en mémoire
    http://www.shellunix.com/awk.html

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
     
    awk '
    {
    	#-- lecture jusqu au prochain enreg. "REDRESSEMENT"
    	if ($1 != "REDRESSEMENT") {
    		next
    	}
     
    	#-- Début traitement d un groupe "REDRESSEMENT"
    	champ1=$2
    	getline #-- lecture enreg. suivant
    	if ($0 != "Converge") {
    		next
    	}
    	getline #-- lecture enreg. vide
    	getline #-- lecture enreg. "Effica..."
    	if ($1 != "Efficacité") {
    		print "*** ENR "NR" : Efficacité non trouvé !!!" | "cat 1>&2"
    		exit
    	}
    	print "REDRESSEMENT", champ1, "converge"
    	#-- obs : NF = Number Fields of the record
    	#--       affichage de l avant dernier champ 
    	print "Efficacité : ", $(NF-1), "%"
    } '  fichier.txt > resultat.txt
    resultat.txt :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    REDRESSEMENT 1 converge
    Efficacité :  91.8 %

  5. #5
    Membre averti
    Inscrit en
    Décembre 2006
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 42
    Par défaut
    Merci beaucoup c'est super sympa !!! ça fonctionne comme j'en rêvais

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [XML] Transformer un fichier .XML en Tableau
    Par metatron dans le forum Bibliothèques et frameworks
    Réponses: 16
    Dernier message: 13/10/2012, 16h49
  2. transformer un fichier csv en un autre avec awk
    Par nizartl dans le forum Shell et commandes GNU
    Réponses: 1
    Dernier message: 28/01/2011, 16h02
  3. [PERL] transformation de fichier
    Par bob20000 dans le forum Langage
    Réponses: 6
    Dernier message: 27/07/2006, 11h13
  4. Réponses: 2
    Dernier message: 19/06/2003, 13h48

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo