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

R Discussion :

Remplacer les cellules vides par des NA


Sujet :

R

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2018
    Messages : 20
    Points : 18
    Points
    18
    Par défaut Remplacer les cellules vides par des NA
    Bonjour,

    Je travaille sous R et lors de l'importation d'un fichier csv sur R j'ai des cellules vides.
    Ce que je voudrais c'est de remplacer ses cellules vides par des NA.
    J'ai pu voir qu'il y avait déjà des discussion concernant ce problème mais aucun n'a permis de résoudre mon problème.
    Voici à quoi ressemble ma table :
    Nom : Capture d’écran (24).png
Affichages : 10228
Taille : 30,0 Ko

    Le code que j'utilise pour importer ma table est le suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ref_client <- read.csv("REF_CLT_1CTR_1ALO_20180430.csv", sep = ";", fileEncoding="latin1", na.strings=c(""," ","NA"))
    Merci d'avance pour votre aide.

    Bien cordialement,

    Ali3529

  2. #2
    Membre averti
    Homme Profil pro
    Data scientist
    Inscrit en
    Février 2017
    Messages
    211
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Data scientist
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2017
    Messages : 211
    Points : 343
    Points
    343
    Par défaut
    Bonjour,

    Remplacer quoi par des NAs ?
    Je peux vous proposez ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
     
    #Pour connaitre les expressions 
    expr  = c( unique( ref_client[,1]),unique( ref_client[,2]))
    expr 
    #identifie les expressions à remplacer et mettre entre les cottes ici 
    ref_client[ref_client == " " ] <- NA }

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2018
    Messages : 20
    Points : 18
    Points
    18
    Par défaut
    Je voudrais remplacer les cellules vides par des NA, comme tu peut voir dans l'image que j'ai joint dans mon message précédent, certaine cellule ont des blancs et ce que je voudrais c'est de remplacer ses blancs par des NA.

    En faite mon véritable problème, c'est quand j'essaye de faire une extraction à partir de ce tableau, ça ne marche pas.

    Exemple de code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    a <- ref_client[ref_client$Client == "5001980",]
    Résultats :

    Nom : Capture d’écran (25).png
Affichages : 9983
Taille : 5,5 Ko

    Alors que je devrais avoir :

    Nom : Capture d’écran (26).png
Affichages : 10003
Taille : 8,0 Ko


    Donc je me suis dit que ça doit être les cellules vides qui crée le problème, mais peut-être que ce n'est pas ça ?

    Bien cordialement,

    Ali

    PS : j'ai testé ton code, mais ça ne marche toujours pas !

  4. #4
    Membre du Club
    Homme Profil pro
    Etudiant - Toulouse
    Inscrit en
    Avril 2017
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Etudiant - Toulouse

    Informations forums :
    Inscription : Avril 2017
    Messages : 57
    Points : 42
    Points
    42
    Par défaut
    Bonjour,
    La proposition faites par Marou devrait fonctionner je viens de le faire après avoir créé ta table

    où x est ta table et "" les modalités à changer en NA.
    A mon avis tu a recopié son code sans enlever l'espace qu'il y a entre les guillemets.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ref_client[ref_client == " " ] <- NA
    Tu peux aussi faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ref_client[ref_client == c("", " " ] <- NA
    En espérant t'avoir aidé.

  5. #5
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2018
    Messages : 20
    Points : 18
    Points
    18
    Par défaut
    Désolé mais aucun des codes ne fonctionne, en regardant de plus près mon fichier excel, j'ai remarqué que les cellules vides n'étaient pas vraiment vides, c'est à dire que ces cellules sont remplis d'espace. je pense que c'est pour ça que les codes proposés ne marche pas.

    Bien cordialement,

    Ali

  6. #6
    Membre du Club
    Homme Profil pro
    Etudiant - Toulouse
    Inscrit en
    Avril 2017
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Etudiant - Toulouse

    Informations forums :
    Inscription : Avril 2017
    Messages : 57
    Points : 42
    Points
    42
    Par défaut
    Alors,
    toujours en m'inspirant de Marou :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    exp <- array(unique(ref_client$groupe.de.vendeur)) #On va stocker toutes les modalités différentes pour les identifier et les changer par des NAs à la dernière ligne
    str(exp) #tu vas voir toutes les différentes modalités dans cette variable groupe.de.vendeur
    ref_client[ref_client$groupe.de.vendeur==c(exp)] <- NA #toute ta colonne sera remplacé par des NAs
    tu le fais pour tes deux colonnes.

    Tu peux aussi passer par du vba ou ton sgbd pour nettoyer le fichier avant de l'utiliser sous R

    Mano

  7. #7
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2018
    Messages : 20
    Points : 18
    Points
    18
    Par défaut
    Bon après 2 heures de recherche, j'ai réussi à trouver la source de mon problème.

    Les noms de mes colonnes comportait des caractères spéciaux, du coup lors de l'importation du fichier sous R ça me crée des problèmes donc je ne pouvais manipuler ma table, j'avais perdu l'habitude de vérifier le nom des colonnes, parce que quand c'est moi qui était chargé de la mise en forme des fichier excel j'avais l'habitude de ne pas utiliser les caractères spéciaux, mais cette fois le fichier excel ne venait pas de moi donc gros problème au niveau des noms de colonnes.

    Pour continuer j'ai également fait un Rechercher et Remplacer sur excel, j'a recherché les " " et je les ai remplacé par "", ça prend un peu de temps quand le fichier est volumineux mais bon...

    Ensuite j'ai importé mon fichier sur R et plus de problème.

    PS : Mano j'ai tester ton code et ça m'a l'air d'être bon aussi


    Merci encore pour vos retour,

    Bien cordialement,

    Ali

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

Discussions similaires

  1. Remplacer les champs vides par des 0
    Par feldi dans le forum PL/SQL
    Réponses: 8
    Dernier message: 16/11/2011, 20h56
  2. Réponses: 2
    Dernier message: 28/10/2010, 14h38
  3. Réponses: 5
    Dernier message: 13/12/2006, 16h08
  4. Remplacer les retour chariot par des <br/>
    Par novices dans le forum Langage
    Réponses: 1
    Dernier message: 21/08/2006, 21h11
  5. [VBA-E]Remplir des cellules vides par des 0
    Par Tartenpion dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 12/03/2006, 13h58

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