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 :

création d'un tableau avec des répétitions


Sujet :

R

  1. #1
    Nouveau membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2017
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Aisne (Picardie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2017
    Messages : 80
    Points : 34
    Points
    34
    Par défaut création d'un tableau avec des répétitions
    Bonjour,

    y a t-il un moyen simple avec R pour réaliser la manipulation suivante SVP:

    j'aimerais ajouter une colonne "année" à droite de la colonne variété et reporter les valeurs de rendement pour chaque année afin d'avoir à la fin 3 colonnes: variété , puis une colonne année puis une colonne rendement. Donc les variétés se répétent pour les différentes années.

    J'ai mis un fichier "exemple" en PJ, colonnes A à D = le tableau initial et colonnes G à I, le tableau que j'aimerais obtenir.

    (mon fichier contient beaucoup plus de lignes et colonnes, ici c'est un exemple)

    Merci par avance pour votre aide.
    Bien à vous,
    Margot.
    Fichiers attachés Fichiers attachés

  2. #2
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 421
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 421
    Points : 5 820
    Points
    5 820
    Par défaut
    salut

    sous Excel c'est l’équivalent d'un tableau dynamique
    dans R il faut chercher tableau de contingence
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    #si le jeu de données s'appelle tab
     
    addmargins(xtabs(rendement ~ variété + année, data = tab))
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    #si le jeu de données s'appelle tab
    library(tidyr)
    library(dplyr)
     
    tab %>% spread(variété, rendement) %>% mutate(Total = rowSums(.[-1])) %>% rbind(.,c("Total", colSums(.[-1])))
    Voir l'aide des fonctions addmargins pour les totaux et cbind pour mettre côte à côte les deux tableaux.
    Nous souhaitons la vérité et nous trouvons qu'incertitude. [...]
    Nous sommes incapables de ne pas souhaiter la vérité et le bonheur, et sommes incapables ni de certitude ni de bonheur.
    Blaise Pascal
    PS : n'oubliez pas le tag

  3. #3
    Nouveau membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2017
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Aisne (Picardie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2017
    Messages : 80
    Points : 34
    Points
    34
    Par défaut
    Bonsoir,

    merci pour le retour.
    Avec un TCD je n'ai pas réussi, par contre avec une macro ça fonctionne.
    Cela m'intéresse tout de même de savoir le faire sur R.

    Avec cette formule:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    addmargins(xtabs(rendement ~ variété + année, data = tab))
    ça ne peut pas fonctionner avec R avec la disposition actuelle de mon tableau initial (colonnes A à D pour faire le tableau voulu colonnes G à I), si ?
    Si non, comment dois-je modifier mon tableau initial?

    Merci par avance.
    Margot.
    Fichiers attachés Fichiers attachés

  4. #4
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 421
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 421
    Points : 5 820
    Points
    5 820
    Par défaut
    salut

    avec un TCD cela marche tres bien tu n'as pas les valeur na mais zero ce qui reviens au même
    Nom : Contingence.PNG
Affichages : 106
Taille : 40,0 Ko

    pour le langage R il faut définir ta source
    exemple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    tab <- read.csv2(’bdd.csv’, sep=’ ;’ , header=TRUE)
    PS : je crois que je n'ai pas compris la question tu veut faire l'inverse ?
    passer d'un tableau a deux entre en un tableau a 3 colonne ?
    Nous souhaitons la vérité et nous trouvons qu'incertitude. [...]
    Nous sommes incapables de ne pas souhaiter la vérité et le bonheur, et sommes incapables ni de certitude ni de bonheur.
    Blaise Pascal
    PS : n'oubliez pas le tag

  5. #5
    Nouveau membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2017
    Messages
    80
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Aisne (Picardie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2017
    Messages : 80
    Points : 34
    Points
    34
    Par défaut
    Oui le TDC ne va pas pour 2 raisons, je veux passer de tableau 1 à tableau 2 (voir dessous), je ne crois pas que ça soit possible avec un TDC? et si ça me mets des zéro à la place des na, ça ne va pas non plus car dans mon "vrai" fichier j'ai des zéro (qui sont des valeurs mesurées) et des na quand il n'y a pas de mesures.
    Avec R votre formule va t-elle fonctionner pour passer de mon tableau 1 à mon tableau 2?

    Merci par avance.

    Tableau 1:

    rendement
    variété année1 année2 année3
    var1 2 3 4
    var2 na na 5
    var3 6 5 7

    Tableau 2:

    variété année rendement
    var1 année1 2
    var2 année1 3
    var3 année1 4
    var1 année2 na
    var2 année2 na
    var3 année2 5
    var1 année3 6
    var2 année3 5
    var3 année3 7

  6. #6
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 421
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 421
    Points : 5 820
    Points
    5 820
    Par défaut
    salut


    dans ce cas là utilise la fonction pivot_longer

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    table4a %>% 
     
     pivot_longer(
       cols = starts_with("année"),
       names_to = "année",
       values_to = "rendement" 
     )
    Nous souhaitons la vérité et nous trouvons qu'incertitude. [...]
    Nous sommes incapables de ne pas souhaiter la vérité et le bonheur, et sommes incapables ni de certitude ni de bonheur.
    Blaise Pascal
    PS : n'oubliez pas le tag

Discussions similaires

  1. macro pour créer un tableau avec des répétitions
    Par Margotte02 dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 13/04/2021, 15h16
  2. Réponses: 3
    Dernier message: 14/08/2014, 11h49
  3. Réponses: 5
    Dernier message: 26/08/2006, 12h14
  4. [CSS] Remplacer un tableau avec des colonnes
    Par mullger dans le forum Mise en page CSS
    Réponses: 6
    Dernier message: 22/08/2006, 15h30
  5. [JAR]Création d'un JAR avec des dependances sous Eclipse
    Par muthnik dans le forum Eclipse Java
    Réponses: 4
    Dernier message: 05/07/2005, 17h39

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