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 :

faire la moyenne des colonnes pour un même couple d'id


Sujet :

R

  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Février 2013
    Messages
    606
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 606
    Par défaut faire la moyenne des colonnes pour un même couple d'id
    Bonjour,

    Je voudrais savoir comment faire la moyenne des colonnes score1 et score2 pour un même couple id et name

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    # Exemple:
    dt1 <- matrix(ncol = 4)
    colnames(dt1) <- c("id", "name", "score1", "score2")
    dt2 <- data.frame("id" = (1:2), "name" = c("a", "b"),
                     "score1" =  c(sample(1:10, 2)) , 
                     "score2" = c(sample(1:10, 2)))
    dt1 <- rbind(dt1, dt2)
    dt2 <- data.frame("id" = (1:2), "name" = c("a", "b"),
                      "score1" =  c(sample(1:10, 2)) , 
                      "score2" = c(sample(1:10, 2)))
    dt1 <- rbind(dt1, dt2)
    dt1 <- dt1[-1, ]
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    > dt1
      id name score1 score2
      1    a      2      1
      2    b      7      9
      1    a     10      2
      2    b      2      4
     
    # resultat
      id name score1 score2
      1    a      6      1.5
      2    b      4.5      6.5

  2. #2
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Février 2013
    Messages
    606
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2013
    Messages : 606
    Par défaut
    J'ai trouvé une solution

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    library(dplyr)
    dt1 %>% group_by(id, name) %>% summarise_each(funs(mean))

  3. #3
    Membre Expert
    Inscrit en
    Novembre 2009
    Messages
    707
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 707
    Par défaut fonction aggregate avec des groupes définis par plusieurs variables
    Bonjour,

    Une solution avec la fonction aggregate :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    > dt1 <- data.frame(id=c(1,2,1,2),
    +                   name=c("a","b","a","b"),
    +                   score1=c(2,7,10,2),
    +                   score2=c(1,9,2,4))
    > dt1
      id name score1 score2
    1  1    a      2      1
    2  2    b      7      9
    3  1    a     10      2
    4  2    b      2      4
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    > aggregate(cbind(score1,score2) ~ id+name, data=dt1, mean)
      id name score1 score2
    1  1    a    6.0    1.5
    2  2    b    4.5    6.5
    Cordialement,

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 19/03/2009, 15h53
  2. [access] concatener des colonnes d'une même table
    Par lili1985 dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 12/07/2008, 22h23
  3. Réponses: 6
    Dernier message: 11/12/2007, 01h05
  4. Des colonnes pour une liste
    Par virtuadrack dans le forum C
    Réponses: 3
    Dernier message: 03/12/2007, 19h35
  5. [Requête] faire la somme des max pour chaque utilisateur
    Par novices dans le forum Langage SQL
    Réponses: 3
    Dernier message: 13/02/2007, 11h45

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