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 :

Importer des donnees


Sujet :

R

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 31
    Par défaut Importer des donnees
    Bonsoir,

    Je dois lire avec R les données stockées dans un fichier au format texte (.txt). Ce fichier contient 11 colonnes de données et le nom de certaines colonnes occupe les 2 premières lignes. Pour le moment j'ai les commandes suivantes :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    chemin<-"http://chemin pour accéder au fichier"
    donnees<-read.table(paste(chemin,"nom_fichier.txt",sep=""),header=T)
    donnees
    Je n'arrive pas à récupérer les données, il y a un message d'erreur qui s'affiche :

    Erreur dans scan(file, what, nmax, sep, dec, quote, skip, nlines, na.strings, :
    la ligne 2 n'avait pas 13 éléments


    Clairement, le problème se situe au niveau des 2 premières lignes, celles contenant les noms de colonne. Pouvez-vous, s'il vous plaît, m'indiquer une solution? D'avance je vous remercie pour votre(vos) réponses(s).

  2. #2
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 059
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 059
    Par défaut
    Bonjour,

    Sans voir un exemple des premières lignes du fichier de données, pas facile de faire au mieux...
    Une solution consiste à indiquer que le fichier ne contient pas les noms des colonnes et de dire à R de sauter les 2 premières lignes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    donnees<-read.table(paste(chemin,"nom_fichier.txt",sep=""),header=F, skip = 2)
    Ensuite, il faudra renommer les colonnes du data frame obtenu avec la fonction names().
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  3. #3
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2012
    Messages : 23
    Par défaut
    Ah oui, j'avais pas pensé au skip. Bonne idée.

    Cela peut venir de plusieurs choses :
    Le système de décimale utilisé ( par défaut R met un ".", regarde si ton tableau ne fonctionne pas à "," typiques des français)

    + d'autres choses mais sans voir le jeu de données, c'est pas évident

    Je te conseille la procédure suivante :
    enregistre ton fichier en csv (séparateur ; )
    puis :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    x<-choose.files()
    donnees<-read.csv(x,header= T, dec=".",sep=";")
    Si tu as des données vides tu peux rajouter
    na="NA" parce que R ne sait pas gérer.

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    31
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 31
    Par défaut
    Bonjour,
    Merci beaucoup pour vos réponses. Voici en fichier joint un exemple de fichier que j'utilise. Employer "skip" pour enlever les deux premières lignes (celles des en-têtes) est effectivement une solution pratique. Pouvez-vous me donner un exemple de l'utilisation de "names()" pour récupérer par la suite les en-têtes enlevés auparavant ?
    Fichiers attachés Fichiers attachés

  5. #5
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 059
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 059
    Par défaut
    Il est préférable d'éviter les espaces et les accents dans les noms de colonnes d'un data frame sous R.
    Du coup, après l'import des données, vous pouvez toujours renommer les colonnes comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    donnees <- read.table(paste(chemin,"nom_fichier.txt",sep=""),header=F, skip = 2)
    names(donnees) <- c("semaine", "magasin1", "magasin2", "temps", "scolaire", "laitier", "fruits", "parfum", "boisson", "epicerie", "textile")
    C'est un exemple, à vous de l'adapter à votre convenance.
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  6. #6
    Inactif
    Profil pro
    Inscrit en
    Avril 2012
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2012
    Messages : 96
    Par défaut
    Bonjour,
    peut-être qu'il faudrait aussi que tu regardes ta deuxième ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Semaine magasin   magasin   type de  fournitures produits fruits & parfumerie boissons epicerie textile 
               1         2       temps    scolaires  laitiers  legumes
    elle n'est pas bien structurée.
    Il faut juste la re-arranger et dans read.tablen'oublie pas de mettre dec="," .

  7. #7
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 4
    Par défaut attention aux espaces
    Ton problème vient à mon avis des espaces dans les noms des colonnes.
    J'ai eu le même problème avec un fichier ayant des tabulations comme séparateur de colonnes et des retour-chariot comme fin de ligne.
    Mais il m'a pris en compte les espaces comme des tab, ce qui fait que certaines lignes comprenaient,selon R, plus de colonnes que la première ligne, car j'avais des espaces dans certaines cellules du tableau.
    J'ai mis un underscore à la place des espaces et tout s'est bien passé ensuite.
    Je précise que je suis sous Mac, je ne sais pas si ce bug est spécifique à cette version.

Discussions similaires

  1. importer des donnees dans word
    Par neuneu1 dans le forum Delphi
    Réponses: 11
    Dernier message: 13/05/2007, 01h32
  2. [9i] Importer des données Excel dans une table
    Par oasma dans le forum SQL
    Réponses: 6
    Dernier message: 19/03/2007, 07h39
  3. Importer des données Access dans Excel
    Par petitloup71 dans le forum Access
    Réponses: 7
    Dernier message: 30/08/2006, 14h48
  4. Importer des donnees avec fichier txt
    Par flOZ dans le forum Requêtes
    Réponses: 8
    Dernier message: 21/04/2006, 17h26
  5. importer des donnees dans interbase
    Par ms91fr dans le forum InterBase
    Réponses: 3
    Dernier message: 25/11/2002, 17h43

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