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 :

Différence entre 2 dates par individu


Sujet :

R

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Webmarketer
    Inscrit en
    Mai 2016
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Webmarketer

    Informations forums :
    Inscription : Mai 2016
    Messages : 8
    Points : 7
    Points
    7
    Par défaut Différence entre 2 dates par individu
    Bonjour,

    J'ai besoin de votre aide pour résoudre mon problème sur R. J'ai une table avec 2 variables : ID et date. Pour un ID unique, j'ai potentiellement plusieurs lignes avec des dates différentes.
    L'idée est de calculer le temps (différence entre 2 dates) et d'en faire une moyenne par ID.

    Voici un exemple de données :
    ID date
    1 21/02/2013
    1 21/02/2014
    2 21/03/2013
    3 22/02/2014
    3 23/02/2014

    Le résultat sera par exemple :
    ID date diff
    1 21/02/2013 NA
    1 21/02/2014 365
    2 21/03/2013 NA
    3 22/02/2014 NA
    3 23/02/2014 1

    La variable diff est la différence entre 2 lignes consécutives mais uniquement si l'ID est le même (c'est là où je suis bloqué).

    Est ce que quelqu'un aurait une idée pour résoudre ce problème facilement ?

    Merci beaucoup

  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 : 35
    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
    Points : 2 673
    Points
    2 673
    Par défaut
    Bonjour,

    Une solution possible, en bidouillant un peu (mais il y a sûrement moyen de faire "plus propre" ^^) :

    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    # création d'un jeu de données d'exemple
    X <- data.frame(ID = c(1, 1, 1, 2, 3, 3), date = c("21/02/2013", "21/02/2014", "22/02/2014", "21/03/2013", "22/02/2014", "23/02/2014"))
     
    # la variable "date" est passée au format "date" de R pour calculer la différence avec la fonction "diff"
    X$date <- as.Date(X$date, format = "%d/%m/%Y")
     
    # la variable "ID" est passée au format "factor" pour servir d'indice dans la fonction "by"
    X$ID <- factor(X$ID)
     
     
    # création d'une fonction "maison" qui permet de faire le "diff" des dates et ajouter en même temps les NA nécessaires
    myfun <- function(x)
    {
        z <- as.numeric(diff(x))
        if(length(z)==0)
        {
          s <- NA
        }
        else
        {
          s <- c(NA, z)
        }
        return(s)
    }
     
    # calcul du vecteur de différences comme demandé :
    df <- by(X$date, X$ID, myfun)
     
     
    # résultat :
    X <- data.frame(X, diff = unlist(df))
    X
       ID       date 	 diff
      1 	    2013-02-21   NA
      1 	    2014-02-21   365
      1  	    2014-02-22   1
      2  	    2013-03-21   NA
      3  	    2014-02-22   NA
      3  	    2014-02-23   1
    Egalement, pour ce genre de manip', un package plutôt pratique : dplyr.

    HTH !


    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
    Futur Membre du Club
    Homme Profil pro
    Webmarketer
    Inscrit en
    Mai 2016
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Webmarketer

    Informations forums :
    Inscription : Mai 2016
    Messages : 8
    Points : 7
    Points
    7
    Par défaut
    Merci beaucoup !!

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

Discussions similaires

  1. [10g] Calculer la différence entre deux dates par mois
    Par sirty dans le forum PL/SQL
    Réponses: 4
    Dernier message: 14/04/2015, 11h51
  2. Obtenir la différence entre 2 dates par tabulation
    Par alicia26 dans le forum ASP.NET
    Réponses: 10
    Dernier message: 04/09/2009, 14h05
  3. différence entre 2 dates
    Par MANU_2 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 12/09/2005, 16h30
  4. Différence entre deux dates
    Par pittzz dans le forum Oracle
    Réponses: 5
    Dernier message: 18/07/2005, 12h24
  5. Comment obtenir la différence entre deux dates ?
    Par jbat dans le forum Langage
    Réponses: 4
    Dernier message: 02/06/2005, 09h34

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