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 ne fonctionne pas pour comparer 2 fichiers plats ayant des champs differents


Sujet :

Shell et commandes GNU

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2012
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Mars 2012
    Messages : 1
    Points : 1
    Points
    1
    Par défaut awk ne fonctionne pas pour comparer 2 fichiers plats ayant des champs differents
    Bonjour,
    je suis nouveau, d'avance, excusez mes erreurs.

    J'ai 2 fichiers plats en entrée.
    La structure du fichier FIC1 est:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Date (format : YYYY-MM-JJ) 
    Heure (format : HH:MM:SS)
    Vendeur (nom char (50))
    Feature (nom char (50))
    QTY Total ( integer)
    Qty Used (integer)
    La structure du fichier FIC2 est:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Date (format : YYYY-MM-JJ) 
    Heure (format : HH:MM:SS)
    Vendeur (nom char (50))
    Feature (nom char (50))
    Login (nom char (50))
    libelle (value :"floating")
    Version1 (value :"XX")
    Version2 (value :"XX")
    hostuser (nom char (50))
    Name server (nom char (50))
    Dans les 2 fichiers Tous les champs sont séparés par un "ESPACE".
    Je m'oriente donc vers awk, mais sans succès pour le moment.
    L'idée est de parcourir les 2 fichiers plats en entrée.
    Si je trouve une ligne dans le FIC1 dont les 4 premiers champs sont identiques à ceux d'un enregistrement du fichier FIC2
    Alors, écrire toutes les lignes de FIC2 correspondant à ces critères sachant qu'il peut y avoir plusieurs lignes commençant par les 4 premiers champs mais les champs 5 et suivant peuvent être différents.

    J'ai cherché sur le net sans trouver ce que je voulais ou quelque chose d'approchant.
    J'ai voulu m'orienter vers les commandes sort suivie d'un pipe suivie d'un join, mais je viens de voir
    que le join d'Unix fait une jointure sur 1 et 1 seul champs commun dans les 2 fichiers.
    En plus, pour trier un fichier, je dois mal m'y prendre car je n'y arrive pas.
    j'ai bien sur trouvé une commande awk comme:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk -F";" 'NR==FNR {a [$1]=$2;next}{if ($2 in a)print a[$2]";"$0; else print "not found"";"$0; }' file2 file1
    Si quelqu'un peut m'expliquer comment avec cette ligne on les 2 fichiers file 1 et file 2 et qu'on teste si une ligne de l'un est dans l'autre,
    alors, je suis vraiment preneur.
    j'ai essayé ceci dans tous les sens mais sans succès; même en ajoutant BEGIN {OFS=FS=";"}Cela ne fonctionne pas soit avec erreur de syntaxe soit écrivant la même chose dans mes 2 fichiers en sortie.
    Pour mes 2 fichiers de sortie, le codage est : awk -F";" -v of1=$FICSORTIE1 -v of2=$FICSORTIE2.
    Ces 2 variables étant initialisées avant.

    Je ne comprends vraiment pas comment cela fonctionne pour d'autres.
    J'ai vraiment besoin d'aide.
    Merci beaucoup par avance.

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 549
    Points : 19 377
    Points
    19 377
    Par défaut
    Bonjour,

    Tous les champs sont séparés par un "ESPACE".
    FS = Field Separator !

    il s'agit de ton cas d'utiliser les champs qui peuvent être identiques dans les deux fichiers en tant qu'indice d'un tableau construit lors de la lecture du premier fichier (NR==FNR), puis, quand awk lit le deuxième fichier, de tester si les champs qui peuvent être identiques dans les deux fichiers existent dans le tableau, si c'est le cas, alors afficher la ligne.

    cf. Gawk User's manual
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 243
    Points : 13 458
    Points
    13 458
    Par défaut
    Bonjour

    Je soussigne tout ce qu'a dit N_BaH et j'ajoute ma pierre à l'édifice.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk '(NR==FNR){tableau[$1 $2 $3 $4]=1;next;} {printable=false;for (i in tableau) if ($1" "$2" "$3" "$4 == i) printable=true; if (printable) print;}' fichier1 fichier2
    Bon ben finalement j'ai tout écrit.
    Mais pas tester.
    Le reste est cosmétique.
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

Discussions similaires

  1. Commande awk pour comparer deux fichiers
    Par miketidy dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 15/03/2010, 19h45
  2. La propriété Appearance ne fonctionne pas pour un commandbutton
    Par ludoche dans le forum VB 6 et antérieur
    Réponses: 9
    Dernier message: 23/11/2007, 13h54
  3. API magique pour comparer deux fichiers?
    Par miria.vhg dans le forum API standards et tierces
    Réponses: 2
    Dernier message: 11/07/2007, 11h06
  4. A:hover ne fonctionne pas pour mon menu css
    Par kaylah dans le forum Mise en page CSS
    Réponses: 5
    Dernier message: 13/03/2007, 15h02
  5. Réponses: 13
    Dernier message: 20/07/2004, 08h54

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