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 :

Problème de concaténation


Sujet :

Shell et commandes GNU

  1. #1
    Membre à l'essai
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Septembre 2014
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Septembre 2014
    Messages : 22
    Points : 10
    Points
    10
    Par défaut Problème de concaténation
    Bonjour a vous le forum,

    Je vous fais part de mon souci.
    J'ai 2 fichiers structurés de la même façon mais ne comportant pas les mêmes paramètres :

    fic1.txt :
    [1234]
    param1=toto
    param2=titi

    [5678]
    param1=gogo
    param2=gege

    fic2.txt:
    [1234]
    param3=hello

    [5678]
    param3=fifi

    Ce que je souhaite faire, c'est de pouvoir obtenir le résultat suivant à l'aide d'un script shell :

    fic.txt:
    [1234]
    param1=toto
    param2=titi
    param3=hello

    [5678]
    param1=gogo
    param2=gege
    param3=fifi

    Comment puis-je procéder ??
    Merci de votre aide.

  2. #2
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 266
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 266
    Points : 12 681
    Points
    12 681
    Par défaut
    Bonjour,
    Une solution via awk (peut mieux faire):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $ awk '/^\[/ {A=$0;next};!/^$/ {print A,$0}' fic1.txt fic2.txt | sort | awk 'BEGIN{X=""};A != $1 {A=$1;print X$1;X="\n"};{sub(".*"$2,$2);print $0};END{print ""}'
    [1234]
    param1=toto
    param2=titi
    param3=hello
     
    [5678]
    param1=gogo
    param2=gege
    param3=fifi
    Cordialement.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Septembre 2014
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Septembre 2014
    Messages : 22
    Points : 10
    Points
    10
    Par défaut
    awk le fait même très bien donc c'est une solution viable =) il m'a généré mon fichier comme je le voulais.
    Juste par curiosité, si c'est possible d'avoir quelques détails sur le déroulement de la commande afin que je puisse mieux la comprendre, ça serait super.
    Un grand merci pour cette commande.

  4. #4
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 539
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 539
    Points : 19 361
    Points
    19 361
    Par défaut
    Citation Envoyé par disedorgue
    Une solution via awk (peut mieux faire)
    Citation Envoyé par lacava
    awk le fait même très bien donc c'est une solution viable
    une unique instance de awk (il peut effectuer des tris égalerment) est très probablement capable de faire la même chose.
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  5. #5
    Expert éminent sénior Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 238
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 238
    Points : 13 443
    Points
    13 443
    Par défaut
    Bonjour,

    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
    26
    27
    28
    $ cat fic1.txt
    [1234]
    param1=toto
    param2=titi
     
    [5678]
    param1=gogo
    param2=gege
     
    $ cat fic2.txt
    [1234]
    param3=hello
     
    [5678]
    param3=fifi
     
    $ awk '/^\[/{a=$0;next} !/^$/{tab[a]= ""tab[a]$0"\n"} END{for (a in tab) print a"\n"tab[a];}' fic*.txt
    [1234]
    param1=toto
    param2=titi
    param3=hello
     
    [5678]
    param1=gogo
    param2=gege
    param3=fifi
     
    $
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

Discussions similaires

  1. Problème de concaténation / conversion
    Par ero-sennin dans le forum C
    Réponses: 5
    Dernier message: 21/03/2006, 12h06
  2. [Tableaux] problème syntaxe concaténation variable
    Par mussara dans le forum Langage
    Réponses: 3
    Dernier message: 01/03/2006, 12h24
  3. Problème de concaténation sous EXCEL
    Par ikki78 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 17/11/2005, 18h17
  4. [Tableaux] problème de concaténation
    Par ludovik dans le forum Langage
    Réponses: 3
    Dernier message: 13/09/2005, 14h24
  5. Problème de concaténation
    Par Proktor dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 06/07/2005, 16h00

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