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 :

Pivot longer tidyverse


Sujet :

R

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Femme Profil pro
    biostatisticie,
    Inscrit en
    Novembre 2021
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 27
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : biostatisticie,

    Informations forums :
    Inscription : Novembre 2021
    Messages : 5
    Par défaut Pivot longer tidyverse
    Bonjour à tous,

    je début sur R et j'ai plusieurs données qui sont le nom de mes colonnes, mean_T0, mean_T1, mean_T2 et sd_T0, sd_T1, sd_T2, j'aimerai utiliser la fonction pivot_longer afin d'avoir une variable temps temps en colonne : T0, T1, T2 et pour chacun des temps avoir la valeur mean et sd correspondante.

    J'arrive avec la fonction suivante à passer en colonne seulement pour la moyenne, je me demande comment faire pour passer la moyenne et sd en colonne en même temps, sachant que les 2 temps sont les mêmes à chaque fois ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    sum_long <- sum %>%
      pivot_longer(
         cols = starts_with("mean_")
         names to="time"
         names_prefix="mean_p"
         values_to="mean"
         values_drop_na= TRUE
    )
    Merci d'avance,

    Bonne soirée

  2. #2
    Expert confirmé
    Avatar de olivier.decourt
    Homme Profil pro
    Formateur R/SAS/statistiques
    Inscrit en
    Avril 2008
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations professionnelles :
    Activité : Formateur R/SAS/statistiques
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 064
    Par défaut
    Bonsoir.
    Je le ferais en deux étapes.
    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
    test <- data.frame(groupe=LETTERS[1:3],
                       mean_T0=runif(3),
                       mean_T1=runif(3),
                       mean_T2=runif(3),
                       sd_T0=runif(3),
                       sd_T1=runif(3),
                       sd_T2=runif(3))
     
    library(tidyr)
     
    test %>% pivot_longer(cols = starts_with(c("mean_","sd_")),
                          names_to = c("stat","temps"),
                          names_pattern = "(.*)_T(\\d+)") %>% 
             pivot_wider(id_cols = c("groupe","temps"),
                         names_from = "stat")

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

Discussions similaires

  1. utilisation de "PIVOT" et TRANSFORM"
    Par boris_ska dans le forum PostgreSQL
    Réponses: 4
    Dernier message: 15/06/2005, 13h00
  2. [LG]Matrice et pivot de Gauss
    Par Loopingus dans le forum Langage
    Réponses: 3
    Dernier message: 16/03/2005, 17h26
  3. Pivoter les réultats d'une requete SQL
    Par elitost dans le forum Langage SQL
    Réponses: 5
    Dernier message: 06/09/2004, 17h55
  4. PIVOT
    Par seddik_saber dans le forum Langage SQL
    Réponses: 5
    Dernier message: 24/05/2004, 12h28
  5. Ellipse d'un tube pivotant
    Par clovis dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 18/03/2004, 21h49

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