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 :

Remplacement des cellules par la valeur précédente


Sujet :

SAS Base

  1. #1
    Membre du Club
    Inscrit en
    Juillet 2009
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 48
    Points : 44
    Points
    44
    Par défaut Remplacement des cellules par la valeur précédente
    Bonjour,
    mon problème est simple à exposer mais apparement difficilement réalisable car cerla fait plus de 2 heures que je cherche la solution.
    En fait, j'ai une variable qui s'incrémente mais qui contient des erreurs. celles-ci sont faciles à trouver, c'est à l'endroit où la variable est négative. Je cherche donc à remplacer cette valeur par la valeur précédente.
    Exemple :
    1
    6
    -2
    -2
    16
    20
    -3
    21

    et je souhaite obtenir
    1
    6
    6
    6
    16
    20
    20
    21

    Voici mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    #data test;
    if var<0 then var=lag(var);
    run;#
    Merci d'avance pour votre aide

  2. #2
    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 : 47
    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
    Bonjour.
    LAG ne renvoie pas la valeur de l'observation précédente, mais la valeur collectée à l'occasion du précédent LAG. Donc appelé dans un IF, tu n'auras jamais la valeur attendue.
    Même en sortant le LAG de son IF, il reste un problème : les valeurs négatives consécutives comme dans ton exemple.
    Mieux vaut "mémoriser" la dernière bonne valeur (et la protéger avec un RETAIN) et la proposer en remplacement quand la valeur est négative.
    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
    DATA work.test ;
      INPUT var ;
    DATALINES ;
    1
    6
    -2
    -2
    16
    20
    -3
    21
    ;
    RUN ;
    DATA work.rectifie (DROP=correct) ;
      SET work.test ;
      RETAIN correct ;
      IF var >= 0 THEN correct=var ;
      ELSE var=correct ;
    RUN ;
    Bon courage.
    Olivier

  3. #3
    Membre du Club
    Inscrit en
    Juillet 2009
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 48
    Points : 44
    Points
    44
    Par défaut
    Merci beaucoup por votre aid c'est exactement ce qu'il me fallait. En effet je n'avais absolument pas pensé au retain!!

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 07/03/2015, 07h52
  2. Réponses: 22
    Dernier message: 20/10/2014, 09h44
  3. Remplacer des cellules par leurs valeurs
    Par benoitbs dans le forum Excel
    Réponses: 1
    Dernier message: 28/01/2008, 12h21
  4. Remplacer des balises par des valeurs dans une String
    Par RadicalBob dans le forum Langage
    Réponses: 4
    Dernier message: 26/04/2007, 16h22
  5. Réponses: 4
    Dernier message: 30/05/2006, 18h21

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