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

Macro Discussion :

[Macro] Supprimer les valeurs manquantes colonnes par colonnes


Sujet :

Macro

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    526
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 526
    Points : 224
    Points
    224
    Par défaut [Macro] Supprimer les valeurs manquantes colonnes par colonnes
    Salut,

    J'ai vu dans la fac que pour enlever une valeur manquante, il fallait faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    data nouv;
    set anc;
    if var1=. then delete;
    run;
    Le problème, c'est que ça va supprimer tous la ligne de la table.
    Comment peut-on supprimer les valeurs manquantes colonne par colonne sans que ça supprime à chaque fois la ligne pour les autres variables?

    Merci.

  2. #2
    Responsable SAS


    Inscrit en
    Septembre 2006
    Messages
    3 176
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 176
    Points : 16 219
    Points
    16 219
    Par défaut
    Bonjour,
    Juste une question : Dans ce cas tes variables ne pourront pas être analysées en mulidimensionnelle, n'est-ce pas génant?
    Les balises code
    FAQ SAS
    Rubrique SAS

    Si vous souhaitez contribuer à la rubrique SAS, contactez-moi ou tout autre membre de l'équipe BI par MP.

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    526
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 526
    Points : 224
    Points
    224
    Par défaut
    Non, cela n'a pas d'importance car c'est pour pratiquer une transformation en coefficients d'ondelettes

  4. #4
    Expert confirmé
    Avatar de olivier.decourt
    Homme Profil pro
    Formateur R/SAS/statistiques
    Inscrit en
    Avril 2008
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Activité : Formateur R/SAS/statistiques
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 064
    Points : 4 478
    Points
    4 478
    Par défaut
    Quand tu dis que tu veux supprimer "juste cette valeur", quel est l'effet au final ? On remonte toutes les valeurs qui suivent d'une observation ? Comme quand on supprime une cellule dans Excel ?
    Bon courage.
    Olivier

  5. #5
    Membre émérite

    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mars 2005
    Messages
    1 364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 364
    Points : 2 329
    Points
    2 329
    Par défaut
    c'est compliqué!!!!
    je pense à un truc mais 'peut être que c'est un peu fou'. tu mets chaque colonne de ta table dans une table, tu nettoies les lignes vides; et tu merges les tables après..
    Consultez les FAQs et les anciens postes avant de poser vos questions. Merci

  6. #6
    Membre actif
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    526
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 526
    Points : 224
    Points
    224
    Par défaut
    Je pense que ça va être difficile car j'ai une table de 20000 colonnes et 35000 lignes, donc...

    Par contre, à la place de supprimer la valeur manquante, si je voudrais la remplacer par la moyenne de ma colonne.

    J'ai pensé à stocker l'ensemble des valeurs moyenne de chaque colonne dans des macro variables à l'aide d'une proc sql mais c'est super lourd en temps de calcul.

    Mon code actuel est :

    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
    proc sql noprint;
    %do k=1 %to 20000;
    select mean(var&k.) into: moy&k.
    from table;
    %end;
    quit;
     
    data table;
    set table;
    %do j=1 %to 20000;
    if var&j.=. then do;
    var&j.=&&moy&k.;
    end;
    %end;
    run;
    Si qq pense à une solution plus simple et surtout moins lourde.

    Merci.

  7. #7
    Responsable SAS


    Inscrit en
    Septembre 2006
    Messages
    3 176
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 176
    Points : 16 219
    Points
    16 219
    Par défaut
    Bonjour,
    Tu peux aussi calculer tes valeurs manquantes par une régression!!
    Les balises code
    FAQ SAS
    Rubrique SAS

    Si vous souhaitez contribuer à la rubrique SAS, contactez-moi ou tout autre membre de l'équipe BI par MP.

  8. #8
    Membre actif
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    526
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 526
    Points : 224
    Points
    224
    Par défaut
    C'est à dire, je ne comprend pas.

  9. #9
    Responsable SAS


    Inscrit en
    Septembre 2006
    Messages
    3 176
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 176
    Points : 16 219
    Points
    16 219
    Par défaut
    Pour une donnée manquante tu considères que c'est ta variable à expliquer (Y), tes variables explicatives étant les autres variables non manquantes!!
    Les balises code
    FAQ SAS
    Rubrique SAS

    Si vous souhaitez contribuer à la rubrique SAS, contactez-moi ou tout autre membre de l'équipe BI par MP.

  10. #10
    Expert confirmé
    Avatar de olivier.decourt
    Homme Profil pro
    Formateur R/SAS/statistiques
    Inscrit en
    Avril 2008
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Activité : Formateur R/SAS/statistiques
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 064
    Points : 4 478
    Points
    4 478
    Par défaut
    En SQL, tu peux dire dans ton SELECT COALESCE(maVariable, MEAN(maVariable)) AS maVariable pour remplacer les valeurs manquantes par la moyenne. En bouclant sur tous les noms des variables, ça fonctionne.

    Sinon, plus court & simple, la proc STDIZE, avec les options REPONLY et METHOD=MEAN, te permettra de combler les "trous" de tes données par la moyenne (éventuellement BY). Mais il faut une licence SAS/STAT.

    Olivier
    Bon courage.
    Olivier

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

Discussions similaires

  1. [Toutes versions] Supprimer des colonnes avec MACRO dont les valeurs sont utilisées
    Par info009 dans le forum Excel
    Réponses: 2
    Dernier message: 06/05/2014, 14h43
  2. Réponses: 2
    Dernier message: 05/09/2013, 09h13
  3. comment remplir les valeurs nulles d'une colonne par des zeros '0'
    Par sinoun dans le forum Développement de jobs
    Réponses: 2
    Dernier message: 21/09/2011, 16h38
  4. Réponses: 3
    Dernier message: 10/06/2011, 10h51
  5. extraire les valeurs différentes d'une colonne
    Par mementox dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 01/12/2007, 16h06

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