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 :

Evaluer une apostrophe dans une Macro-condition


Sujet :

Macro

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2014
    Messages : 15
    Points : 15
    Points
    15
    Par défaut Evaluer une apostrophe dans une Macro-condition
    Bonjour à tous,
    j'ai un problème: j'aimerais créer une condition selon qu'une chaine de caractère contienne le symbole " ' "
    le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    %if %substr(&wherereqfiltre.,&pos_date.,1) ne "'" %then %do;
    me donne le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ERROR: A character operand was found in the %EVAL function or %IF condition where a numeric operand is required. The condition was: 
           %substr(&wherereqfiltre.,&pos_date.,1) ne "'" 
    ERROR: The macro TEST will stop executing.
    j'ai essayé en incluant "%str(%')" à la place mais ça fait la même erreur.

    Quelqu'un sait il comment je peux faire ?
    Merci et bonne journée.

  2. #2
    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,
    As-tu essayé avec ?
    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 à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2014
    Messages : 15
    Points : 15
    Points
    15
    Par défaut
    Non j'ai essayé aussi mais ça ne marche pas

  4. #4
    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
    L'erreur vient de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    %if %substr(&wherereqfiltre.,&pos_date.,1)
    peux tu nous donner un exemple de valeurs pour les macro variable wherereqfiltre et pos_date ?
    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

  5. #5
    Membre expérimenté
    Homme Profil pro
    Développeur en SAS/ Statisticien
    Inscrit en
    Janvier 2013
    Messages
    482
    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 : 482
    Points : 1 547
    Points
    1 547
    Par défaut
    Bonjour,
    Je pense que le symbole (') est à l'origine du problème. Pour le capter et faire la comparaison avec la macro fonction %str(%'), je te propose la démonstration suivante sur laquelle se fonde ton code. Tu peux essayer :

    Démonstration:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    %let text=%bquote(yyh'gds); 
    %let text1=%bquote(%substr(%bquote(&text), 4, 1)) ;
    %put text__= &text1 ;
    Ton code à vérifier:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    %if %bquote(%substr(%bquote(&wherereqfiltre.), &pos_date., 1)) ne %str(%') ;
    Cdt
    Ward

  6. #6
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2014
    Messages : 15
    Points : 15
    Points
    15
    Par défaut
    Merci pour vos réponses.
    La technique bquote est pas mal, la variable text1 est bien réduite à '.
    Cependant l'adapter dans une condition ne fonctionne pas et donne les mêmes erreurs que mon bout de code.
    Sam:
    %if %substr(&wherereqfiltre.,&pos_date.,1)

    avec :
    whereeqfiltre date_1=30MAR15:12:45:14 OR modele='IMPORT MANUEL' or date_2=30MAR15:12:45:14;

    pos_date change dans une boucle pour se placer successivement entre chaque =3.(soit 8 pour la première étape)
    Le but est de rajouter un ' avant la date et un 'dt à la fin pour l'utiliser dans un filtre, mais si les deux dates sont identiques, le '...'dt est ajouté pour les deux dates dès la première étape car même si on précise à SAS à quel niveau de la chaine de caractère on veut effectuer une modification grâce au %substr, il le fera pour chaque occurrence de la sous-chaine rencontrée dans la chaine principale (wherereqfiltre) ,
    Le but est de mettre la condition de mon premier post pour ne pas refaire cette modification quand elle a déjà été faite.

    En fait ce code fonctionne tant que la condition est "TRUE", autrement dit si je change d'une seconde la date2, le code fonctionne et ajoute bien les '...'dt à chaque date, mais quand elles sont identiques,
    il ajoute directement les '...'dt aux deux dates, et j'ai besoin de la condition de mon premier post pour ne pas remettre des ' ' en trop, mais dès qu'elle est fausse, j'ai ce message d'erreur.

    j'espère avoir été clair, merci de votre aide ou de vos conseils pour éventuellement procéder autrement

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

Discussions similaires

  1. [XL-2007] Afficher une checkbox dans une feuille si une checkbox d'une autre feuille est cochée
    Par JessieCoutas dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 18/08/2009, 13h35
  2. portée d'une variable dans une fonction dans une méthode
    Par laurentg2003 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 29/06/2009, 19h05
  3. [POO] dans une classe, appeler une fonction dans une méthode
    Par arnaudperfect dans le forum Langage
    Réponses: 3
    Dernier message: 26/08/2007, 23h04
  4. Envoyer une formulaire dans une page dans une Frame
    Par zooffy dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 29/06/2007, 10h13
  5. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48

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