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 :

Commande join : Rapprochement de deux fichiers


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de Liamm
    Femme Profil pro
    Enseignant
    Inscrit en
    Janvier 2019
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 164
    Par défaut Commande join : Rapprochement de deux fichiers
    Bonjour,
    Voici un petit exercice sur lequel je coince :

    En entrée de la commande join, on a deux fichiers f1 et f2.
    Code f1 : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    a1;A
    b2;B
    d4;D
    e5;E
    m12;M
    Code f2 : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    a1;a
    b2;b
    c3;c
    e5;e
    z26;z
    Voici ce que l'on veut obtenir en les rapprochant;
    La jointure se fait sur le premier champ de chaque fichier.

    enregistrement:
    f1 . . . . . . . . . . f2 . . . . . . . . . . f3(sortie)
    Existe . . . . . . .Existe . . . . . . . prendre les données de f2
    Existe . . . . . . .N'existe pas . . prendre les données de f1
    N'existe pas . .Existe . . . . . . . prendre les données de f2

    En sortie, on cherche donc à avoir :
    Code f3 : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    a1;a
    b2;b
    c3;c
    d4;D
    e5;e
    m12;M
    z26;z

    voici une première approche, mais non satisfaisante :

    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
    liam@HAL42:~/projets/Test_cmd_shell_21$ ./zjoin.sh 
    cat xjoinf1.csv -n
         1	a1;A
         2	b2;B
         3	d4;D
         4	e5;E
         5	m12;M
    cat xjoinf2.csv -n
         1	a1;a
         2	b2;b
         3	c3;c
         4	e5;e
         5	z26;z
    join -t";" -a1 -a2 xjoinf1.csv xjoinf2.csv > xjoinf12.csv
    cat xjoinf12.csv -n
         1	a1;A;a
         2	b2;B;b
         3	c3;c
         4	d4;D
         5	e5;E;e
         6	m12;M
         7	z26;z
    Comment faire ?

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 293
    Par défaut
    Bonjour

    Si la commande join sait répondre à la question, je ne sais pas faire.

    Avec awk, on fait ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $ awk -F';' -vOFS=\; '(FNR==NR){f1[$1]=$2;next;} 1; {f2[$1]=$2;} END{for (i in f1) if (!f2[i]) print i,f1[i];}' f1 f2
    a1;a
    b2;b
    c3;c
    e5;e
    z26;z
    m12;M
    d4;D
    Le premier champ est une clé primaire, bien sûr ?

  3. #3
    Membre confirmé Avatar de Liamm
    Femme Profil pro
    Enseignant
    Inscrit en
    Janvier 2019
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 164
    Par défaut
    Effectivement ça marche très bien avec awk.
    Merci Flodelarab.

    Il va falloir que je m'achète un livre sur awk - gawk pour mieux comprendre ce langage spécifique ! (je ne sais pas lequel (en français serait mieux))

    Et avec la commande join ?
    Est-ce possible ?
    Peut-être avec la "concaténation" des résultats de deux commandes join ? (Si les temps de traitements ne sont pas trop rallongés)

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 293
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $ join -t";" -j 1 -v 1 -o "1.1,1.2" f1 f2
    d4;D
    m12;M
    $ join -t";" -j 1 -v 1 -o "1.1,1.2" f1 f2 | cat f2 -
    a1;a
    b2;b
    c3;c
    e5;e
    z26;z
    d4;D
    m12;M

  5. #5
    Membre confirmé Avatar de Liamm
    Femme Profil pro
    Enseignant
    Inscrit en
    Janvier 2019
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 164
    Par défaut
    Merci Flodelarab, ça marche aussi.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 09/02/2021, 12h19
  2. [XL-2010] Rapprocher deux fichiers excel pour supprimer lignes identiques
    Par operaq dans le forum Excel
    Réponses: 5
    Dernier message: 21/02/2014, 09h33
  3. [Batch] FC Commande (Comparaison de deux fichiers)
    Par moilou2 dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 27/02/2013, 14h49
  4. Commande awk pour comparer deux fichiers
    Par miketidy dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 15/03/2010, 19h45
  5. commande awk + sortie en deux fichiers
    Par nina2007 dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 18/08/2008, 15h54

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