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

SAS Base Discussion :

Réduction table sas


Sujet :

SAS Base

  1. #1
    Membre du Club
    Inscrit en
    Août 2013
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Août 2013
    Messages : 6
    Par défaut Réduction table sas
    Bonjour à tous,

    j'ai un petit problème, j'ai par exemple cette table:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    data jojo;
    input NUMCNT $ var8;
    cards;
    1 2
    1 1
    2 1
    2 2
    3 2
    3 2
    3 1
    3 2
    ;
    run;
    et pour un même numéro de contrat, je ne voudrais garder que les lignes qui commence à var8=1, c'est-à-dire obtenir le tableau suivant:

    1 1
    2 1
    2 2
    3 1
    3 2

    Comment faire ?

    Merci pour votre aide

  2. #2
    Modérateur

    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Février 2011
    Messages
    1 625
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2011
    Messages : 1 625
    Par défaut
    Hello,

    T'as le choix entre proc sql ou proc sort :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    proc sql;
     create table jojo1 as select DISTINCT NUMCNT , var8 from jojo;
    quit;
    ou sinon
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    proc sort data=jojo nodupkey /* noduplicate*/ ;
    by NUMCNT  var8;
    run;
    N'oubliez pas de consulter les FAQ SAS et les cours et tutoriels SAS
    N'oubliez pas de mettre votre message à si la solution donnée résout votre problème

  3. #3
    Membre du Club
    Inscrit en
    Août 2013
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Août 2013
    Messages : 6
    Par défaut
    Merci pour ta réponse rapide, mais ce n'est pas ce que je cherche!

    Pour un même numéro de contrat, je veux juste les enregistrements qui se trouve derrière (et y compris) var8=1.

    Je peux avoir:

    NUMCNT VAR8
    1 2
    1 2
    1 1
    1 2
    1 2

    Et je voudrais juste récupérer:

    1 1
    1 2
    1 2

  4. #4
    Candidat au Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Juillet 2013
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Juillet 2013
    Messages : 4
    Par défaut
    Voici une solution via des transposes et un array :
    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
    29
    30
    data jojo;
    input NUMCNT $ var8;
    cards;
    1 2
    1 1
    2 1
    2 2
    3 2
    3 2
    3 1
    3 2
    ;
    run;
     
    proc transpose data=jojo out=transp1;by numcnt;run;
    data temp;
     set transp1;
     array mes_col{*} col:;
     do i=lbound(mes_col) to hbound(mes_col);
    	if mes_col(i)=1 then do;
    		val_temp=i;
    	end;
     end;
    run;
    proc transpose data=temp out=transp2;by numcnt val_temp;run;
     
    data fin(drop=val_temp _NAME_);
    	set transp2;
    	if substr(_NAME_,4,1)<val_temp or var8=. then delete;
    run;

  5. #5
    Membre Expert
    Homme Profil pro
    Développeur en SAS/ Statisticien
    Inscrit en
    Janvier 2013
    Messages
    483
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur en SAS/ Statisticien
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2013
    Messages : 483
    Par défaut
    Bonjour,
    Je vous propose la solution suivante :
    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
     
    DATA jojo;
    input NUMCNT $ var8;
    cards;
    1 2
    1 1
    2 1
    2 2
    3 2
    3 2
    3 1
    3 2
    ;
    run;
     
    data sata (drop=grp var_) ;
    set jojo ;
    by NUMCNT NOTSORTED ;
    retain grp var_ ; 
    if first.NUMCNT or var8=1 then do ; grp+1 ; var_=var8 ; end ;
    if var_> 1 then delete ;
    run ;
    Cordialement
    Ward

  6. #6
    Membre du Club
    Inscrit en
    Août 2013
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Août 2013
    Messages : 6
    Par défaut
    Merci pour votre aide ! Mon problème est résolu

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

Discussions similaires

  1. Import d'un fichier xml en table SAS
    Par fredrider dans le forum SAS Base
    Réponses: 3
    Dernier message: 25/11/2014, 09h34
  2. Itération entre table SAS et proc sql
    Par marti dans le forum Administration et Installation
    Réponses: 16
    Dernier message: 21/05/2008, 11h43
  3. transformation table SAS
    Par marti dans le forum SAS Base
    Réponses: 4
    Dernier message: 08/04/2008, 20h32
  4. Importer table SAS dans le work
    Par raf64flo dans le forum SAS Base
    Réponses: 8
    Dernier message: 02/04/2008, 14h11
  5. Obtenir la liste des doublons dans une table SAS
    Par marie mouse dans le forum SAS Base
    Réponses: 2
    Dernier message: 05/12/2007, 15h33

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