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 :

Test logique dans 2 colonnes différentes


Sujet :

SAS Base

  1. #1
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Février 2017
    Messages : 13
    Points : 10
    Points
    10
    Par défaut Test logique dans 2 colonnes différentes
    Bonsoir;

    Je sollicite votre aide pour résoudre ce problème: j'ai un exemple comme suit:

    annee animal sexe mere
    2000 10 1 0
    2001 20 2 0
    2003 30 2 10
    2004 40 1 10
    2005 50 2 20
    2006 60 1 30
    2007 70 1 30
    2008 80 2 50

    les animaux de sexe 2 (femelles) peuvent apparaître après n année dans la colonne mère comme mère de i descendants. Je veux chercher et éliminer de la colonne animal ceux qui ont sexe=1 et qui apparaîssent dans la colonne mère (comme par exemple l'animal 10 son sexe=1 et il a 2 descendants: 30 et 40). Ces 2 lignes doivent être éliminée.

    D'avance merci.

  2. #2
    Membre actif
    Homme Profil pro
    Inscrit en
    Février 2013
    Messages
    347
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 347
    Points : 235
    Points
    235
    Par défaut
    Salut,

    Avec la condition IF et l'opérateur AND :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    data analyse;
        set base;
        if sexe = 1 and mere ne 0 then delete;
    run;
    alers

  3. #3
    Modérateur

    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Février 2011
    Messages
    1 624
    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 624
    Points : 3 402
    Points
    3 402
    Par défaut
    Hello,

    Si j'ai bien compris le problème, en SQL on peut faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    proc sql ;
    delete  from ma_table
    where  mere in (select distinct animal from ma_table where  sexe=1 );
    quit;
    Attention le delete en SAS génère un warning sur l'intégrité des données. Sinon il est possible de faire un merge de la table avec elle même. ou même un Excepte dans la proc SQL.
    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

  4. #4
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Février 2017
    Messages : 13
    Points : 10
    Points
    10
    Par défaut
    Citation Envoyé par alers Voir le message
    Salut,

    Avec la condition IF et l'opérateur AND :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    data analyse;
        set base;
        if sexe = 1 and mere ne 0 then delete;
    run;
    alers

    Salut,

    merci de votre réponse mais dans ce cas je vais perdre tous les animaux ayant un sexe=1.

  5. #5
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2017
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Février 2017
    Messages : 13
    Points : 10
    Points
    10
    Par défaut
    Citation Envoyé par s_a_m Voir le message
    Hello,

    Si j'ai bien compris le problème, en SQL on peut faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    proc sql ;
    delete  from ma_table
    where  mere in (select distinct animal from ma_table where  sexe=1 );
    quit;
    Attention le delete en SAS génère un warning sur l'intégrité des données. Sinon il est possible de faire un merge de la table avec elle même. ou même un Excepte dans la proc SQL.
    Salut;

    Merci bien de votre réponse. ça marche bien sur ma base de données mais ça élimine les mères aberrantes seulement de la colonne mère, et je veux qu'elles disparaissent aussi de la colonne animal. Que dois-je rajouter à la proc sql que vous m'avez proposé ???

    PS: je l'ai fait avec le merge mais c'est très long.

    D'avance merci.

Discussions similaires

  1. copier des lignes sous conditions (dans 2 colonnes différentes)
    Par olive08 dans le forum Macros et VBA Excel
    Réponses: 18
    Dernier message: 12/10/2007, 14h44
  2. Réponses: 6
    Dernier message: 29/08/2007, 06h49
  3. Réponses: 10
    Dernier message: 12/06/2007, 10h32
  4. Réponses: 4
    Dernier message: 27/03/2007, 09h49
  5. Réponses: 3
    Dernier message: 06/02/2007, 11h04

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