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

  1. #1
    Candidat au Club
    Femme Profil pro
    Ingénieur R&D
    Inscrit en
    février 2019
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : février 2019
    Messages : 3
    Points : 4
    Points
    4

    Par défaut Joindre 2 listes sans variable commune

    Bonjour,

    Je me lance dans la programmation SAS, je suis donc débutante.

    J'ai 2 tables différentes :
    - identification : qui contient une liste d'Id (Id1, Id2, ...) (qui ne va pas évoluer)
    - date : qui contient une liste de dates (date1, date2, ...) (qui va augmenter chaque jour)
    - attention : ces 2 tables n'ont rien en commun

    Je souhaite faire joindre ces deux listes, afin d'obtenir 1 ligne pour chaque Id à chaque date:
    Id1 - Date 1
    Id2 - Date 1
    Id3 - Date 1
    ...
    Id1 - date 2
    Id2 - date 2
    Id3 - date 3
    ...

    j'ai essayé de créer une variable n=1 dans chacun de mes fichiers pour ensuite utiliser la fonction 'merge', mais cela ne démultiplie pas mes lignes comme je le souhaiterais.
    j'ai également testé les jointures 'Inner join' et jointures externes, mais j'ai le même résultat.

    je n'ai pas réussi à trouver dans le forum la réponse à ma question.
    Est-ce que quelqu'un pourrait m'aider svp ?

    Merci par avance

  2. #2
    Membre éprouvé
    Homme Profil pro
    Statisticien/développeur BI
    Inscrit en
    janvier 2012
    Messages
    319
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Statisticien/développeur BI
    Secteur : Transports

    Informations forums :
    Inscription : janvier 2012
    Messages : 319
    Points : 1 119
    Points
    1 119

    Par défaut

    bonjour,

    Avec une proc sql :

    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
    data id;
    input id $1;
    cards;
    1
    2
    3
    ;
    run;
     
    data date;
    input date :date9.;
    format date ddmmyy8.;
    cards;
    01jan19
    02jan19
    03jan19
    ;
    run;
     
    proc sql;
    	create table TableMerge as select
    		t1.*,
    		t2.*
    	from id t1, date t2;
    quit;

  3. #3
    Candidat au Club
    Femme Profil pro
    Ingénieur R&D
    Inscrit en
    février 2019
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : février 2019
    Messages : 3
    Points : 4
    Points
    4

    Par défaut

    Bonjour,

    Merci beaucoup, c'est exactement ce qu'il me fallait !!

    Juste par curiosité, vous pouvez m'expliquer le principe de cette proc sql ? le fait de mettre une étoile* au bout de t1, cela fait dire qu'il faut démultiplier la ligne ?

    Encore un grand merci

    Bonne journée

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

Discussions similaires

  1. Permuter deux variables sans variable temporaire
    Par khayyam90 dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 09/01/2015, 09h02
  2. Réponses: 0
    Dernier message: 24/04/2014, 14h16
  3. Réponses: 4
    Dernier message: 01/07/2013, 11h27
  4. Réponses: 5
    Dernier message: 20/09/2005, 23h48
  5. threads et variables communes
    Par buzzz dans le forum Windows
    Réponses: 3
    Dernier message: 21/02/2005, 14h39

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