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 :

rbind et liste de fichiers csv


Sujet :

R

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    465
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 465
    Par défaut rbind et liste de fichiers csv
    Bonjour

    C'est encore moi: en ce moment, je suis en pleine analyse de données et je débute sous R d'où ma présence et le fait que je sollicite plus que je n'aide (mais ça viendra, j'espère)

    Voilà, j'ai une liste qui est la suivante:
    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
    > fichiers
    $CALVI
    [1] "c2B050_CALVI_pnb10_parcelle.csv"
     
    $ALGAJOLA
    [1] "c2B010_ALGAJOLA_pnb10_parcelle.csv"
     
    $AREGNO
    [1] "c2B020_AREGNO_pnb10_parcelle.csv"
     
    $BELGODERE
    [1] "c2B034_BELGODERE_pnb10_parcelle.csv"
     
    $CALENZANA
    [1] "c2B049_CALENZANA_pnb10_parcelle.csv"
    J'aimerais annexer les lignes de l'ensemble de ces fichiers via rbind, mais j'obtiens un message d'avis que j'ai peine à déchiffrer. Aussi, ma solution me semble peu élégante...

    La voici:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    resultat<-NA
    for (i in fichiers) resultat<-rbind(read.csv2(i),resultat)
    Il y a sûrement mieux...
    Aussi, que signifie ce message d'avis?

    Merci!

  2. #2
    Modératrice

    Femme Profil pro
    Statisticienne, Fondatrice de la société DACTA
    Inscrit en
    Juin 2010
    Messages
    893
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Statisticienne, Fondatrice de la société DACTA

    Informations forums :
    Inscription : Juin 2010
    Messages : 893
    Par défaut
    Bonjour,

    Vous pouvez peut-être essayer :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    > resultat<-NULL
    > for (i in fichiers) resultat<-rbind(read.csv(file=deparse(i)),resultat)
    Bonne continuation


    Cordialement,

    A.D.

    Forum R
    Fournir le code utilisé (pensez aux balises code !), les packages nécessaires, ainsi qu'un court mais représentatif extrait du jeu de données et les éventuels messages d'erreur.
    Recherche d'informations concernant R : RSiteSearch / tutoriels : http://r.developpez.com/cours/ .

    Pensez également au bouton "Résolu" et à voter (en bas à droite des messages) lorsque vous avez obtenu une réponse satisfaisante.

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    465
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 465
    Par défaut
    ok ça marche très bien.

    merci

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    465
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 465
    Par défaut
    Bonjour,

    Juste pour vous dire que j'ai trouvé une solution plus simple qui consuste à utiliser la fonction reduce:

    Reduce(rbind,list)


  5. #5
    Modératrice

    Femme Profil pro
    Statisticienne, Fondatrice de la société DACTA
    Inscrit en
    Juin 2010
    Messages
    893
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Statisticienne, Fondatrice de la société DACTA

    Informations forums :
    Inscription : Juin 2010
    Messages : 893
    Par défaut
    Bonjour,


    Je ne connaissais pas la fonction "Reduce", c'est bon à savoir.

    Par contre, si vous souhaitiez simplement obtenir un vecteur contenant les noms de fichiers de votre liste, pourquoi avoir utilisé la fonction "read.csv" ?
    Et si vous souhaitiez ouvrir tous les fichiers dont les noms sont contenus dans la liste, je ne vois pas ce que change l'utilisation de "Reduce"...

    Cela dit merci d'être revenu poster cette info


    Cordialement,

    A.D.

    Forum R
    Fournir le code utilisé (pensez aux balises code !), les packages nécessaires, ainsi qu'un court mais représentatif extrait du jeu de données et les éventuels messages d'erreur.
    Recherche d'informations concernant R : RSiteSearch / tutoriels : http://r.developpez.com/cours/ .

    Pensez également au bouton "Résolu" et à voter (en bas à droite des messages) lorsque vous avez obtenu une réponse satisfaisante.

  6. #6
    Membre Expert
    Avatar de pitipoisson
    Homme Profil pro
    Chercheur
    Inscrit en
    Septembre 2006
    Messages
    1 942
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Chercheur
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 942
    Par défaut
    Bonjour,

    Je ne connaissais pas non plus cette fonction, comme quoi on en découvre tous les jours en R !

    Bon pour info - et parce que R offre toujours de multiples possibilité - on peut également utiliser :
    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
    23
    24
    > l <- as.list(letters[1:5])
    > l
    [[1]]
    [1] "a"
    
    [[2]]
    [1] "b"
    
    [[3]]
    [1] "c"
    
    [[4]]
    [1] "d"
    
    [[5]]
    [1] "e"
    
    > do.call(rbind, l)
         [,1]
    [1,] "a" 
    [2,] "b" 
    [3,] "c" 
    [4,] "d" 
    [5,] "e"
    (ne me demandez pas quelles sont les différences fondamentales avec la précédente).

    ou bien encore le très simple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    > unlist(l)
    [1] "a" "b" "c" "d" "e"
    dont le résultat peut évidement être stocké dans une colonne de l'objet de votre choix.

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

Discussions similaires

  1. [Python 3.X] Générer un fichier CSV à partir d'une liste
    Par blueice dans le forum Général Python
    Réponses: 1
    Dernier message: 20/04/2015, 15h38
  2. Créer une liste spécifique d'après un fichier csv
    Par melissar dans le forum Général Python
    Réponses: 6
    Dernier message: 26/04/2012, 11h38
  3. [AC-2003] Exporter le contenu d'une zone de liste dans un fichier CSV
    Par jeje22 dans le forum VBA Access
    Réponses: 11
    Dernier message: 29/04/2010, 16h27
  4. Liste des fichiers CSV dans une feuille
    Par DubDub dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 19/02/2009, 08h05
  5. [O03] - Import depuis fichier CSV en liste de contacts
    Par mathel dans le forum VBA Outlook
    Réponses: 1
    Dernier message: 18/03/2008, 14h29

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