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 :

Suppression des valeurs non numériques


Sujet :

SAS Base

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2011
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2011
    Messages : 155
    Points : 37
    Points
    37
    Par défaut Suppression des valeurs non numériques
    Bonjour,

    J'ai une colonne numerique qui contien aussi des valeurs bizar et je veux garder que mes valeurs numérique .Ya t-il une solution svp?

    exemple:

    COL1
    12451248
    14514517
    15698465
    '/
    14547845
    *ù:
    14578495
    ..:;

    Pour info les valeurs bizar change à chaque fois je n'ai pas toujours la meme valeur.

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    114
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 114
    Points : 158
    Points
    158
    Par défaut
    Bonjour,

    Au vu de ta colonne, je ne pense pas que le type de ta colonne COL1 soit numérique, il est plutôt caractère. Sinon si tu as champs caractère et que tu veux garder les nombre (0 à 9) utilise la fonction compress(qui renvoie un champs texte) comme ci-dessous

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    data matable;
    set matable;
    col_numerique=compress(col1,,'kd');
    run;
    Bon courage .

  3. #3
    Nouveau membre du Club
    Femme Profil pro
    Inscrit en
    Octobre 2012
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2012
    Messages : 30
    Points : 30
    Points
    30
    Par défaut
    Bonjour.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    data table2;
      set table1;
      if anyalpha(col1)>0 then delete;
    run;
    A tester.

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2011
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2011
    Messages : 155
    Points : 37
    Points
    37
    Par défaut ça marche pas
    ça marche pas !!

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2011
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2011
    Messages : 155
    Points : 37
    Points
    37
    Par défaut àa marche pas
    Excusé moi je précise encore ma question je suis dsl:
    ma colonne elle est au début caractére c'est un fichier que j'importe sur sas:

    Col1
    12457841.01
    15487945.5
    15478946.65
    ,,::
    0.1
    14578483.98
    7.5
    3.9
    ..ùù


    je précise que c'est une colonne en ALPHA.
    Les valeurs qui m'intéresse c'est les valeurs avec 8 position avant la virgule et 1 ou 2 position aprés la virgule. (exemple=12457841.01) ou (15487945.5)

  6. #6
    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
    Points : 3 403
    Points
    3 403
    Par défaut
    Hello mister,
    Par exemple:

    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 test;
    input COL1 $12.;
    cards;
    12451248
    14514517
    15698465
    '/
    14547845
    *ù:
    14578495
    ;
    run;
     
     
    data test1 (where=(strip(col1) ne '.' ));
    set test; 
    col1 =col1 *1;
    run;
    Ou :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    data test1 ;
    set test; 
    if 	notdigit(compress(col1))>=1 then delete;
    run;
    Il existe d'autres façon plus élégantes de faire : expression résulières,...

    @ludivine666 : la fonction ANYALPHA cherche uniquement les caractères alphabétiques

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2011
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2011
    Messages : 155
    Points : 37
    Points
    37
    Par défaut ça marche pas
    Hey sam,
    ça marche pas aussi

    J'ai essayé de transformer la colonne en NUM avec un trie sur la colonne et aprés j'ai mis un between pour avoir que les valeurs qui m'intéresse.

    Mais j'aurais toujours besoin de savoir s'il ya des téchniques pour ce genre de souci ?!!


    Merci à vous tous

  8. #8
    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
    Points : 3 403
    Points
    3 403
    Par défaut
    Citation Envoyé par sniper75 Voir le message
    Hey sam,
    ça marche pas aussi
    t'as essayé avec l'exemple que je t'ai donné?
    Je t'ai proposé deux méthodes (Sinon je n'ai pas bien compris ton problème).

    Citation Envoyé par sniper75 Voir le message
    J'ai essayé de transformer la colonne en NUM avec un trie sur la colonne et aprés j'ai mis un between pour avoir que les valeurs qui m'intéresse.
    moi je n'ai pas transformé en numérique
    Citation Envoyé par sniper75 Voir le message
    Mais j'aurais toujours besoin de savoir s'il ya des téchniques pour ce genre de souci ?!!
    quel soucis ?

  9. #9
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2011
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2011
    Messages : 155
    Points : 37
    Points
    37
    Par défaut explication
    Merci sam pour l'intéret que tu porte à ma question:

    oui j'ai su quelque part que tu n'a pas compris mon souci j'éxplique:

    J'ai une colonne en alpha que j'importe sur sas,cette colonne contient des valeurs (15487254.12 14578457.01 .... tu as aussi 0.1 et -7 tu as aussi W ...)

    COL1
    11457845.10
    45178456.23
    74845756.08
    45784595.1
    45789548.2
    ....
    ;,,,
    ùùùùk
    W
    0.1
    0.6
    -7


    A partir de cette colonne je veux garder que les lignes avec des valeurs sur 11 position ou 10 position exemple (11457845.10 ou 45784595.1).

    Bien sur pour info cette colonne je peux l'avoir en alpha et en numérique j'ai le choix ,comme je veux tous dépend de ce que tu me propose comme solution.

    Merci d'avance.

  10. #10
    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
    Points : 3 403
    Points
    3 403
    Par défaut
    A choisir ou à adapter :

    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 test;
    input COL1 $12.;
    cards;
    12457841.01
    15487945.5
    15478946.65
    ,,::
    0.1
    14578483.98
    7.5
    3.9
    ..ùù
    ;
    run;
     
     
    data test1;
    	set test;
    	*IF PRXMATCH("/\d{1,8}.\d{0,2} /",col1) =1;
    	IF PRXMATCH("/\d{8}.\d{1,2} /",col1) =1;
    run;

  11. #11
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2011
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2011
    Messages : 155
    Points : 37
    Points
    37
    Par défaut merci
    Merci !!!
    je vais l'adapter

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

Discussions similaires

  1. [XL-2003] Calcul sur des valeurs non numériques
    Par Katell dans le forum Conception
    Réponses: 10
    Dernier message: 03/02/2015, 16h11
  2. [XL-2007] TCD : afficher des valeurs non numériques
    Par marcelisa2 dans le forum Excel
    Réponses: 3
    Dernier message: 12/03/2014, 19h08
  3. [SQL-2005] Rechercher des caractères non numériques
    Par castaka dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 03/05/2007, 12h12
  4. Réponses: 3
    Dernier message: 24/05/2005, 09h19
  5. Réponses: 6
    Dernier message: 04/04/2003, 16h28

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