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 :

Extraire la Nème ligne


Sujet :

R

  1. #1
    Membre habitué
    Inscrit en
    Février 2003
    Messages
    171
    Détails du profil
    Informations forums :
    Inscription : Février 2003
    Messages : 171
    Points : 126
    Points
    126
    Par défaut Extraire la Nème ligne
    Bonjour,

    Voici un data frame avec 2 colonnes : le nombre d'habitants par ville et le pays.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Pays Ville
    FR   100.000
    FR   75.000
    FR   33.000
    ES   49.000
    ES   42.000
    ES   25.000
    ES   18.000
    Comment extraire la nème ligne pour chaque pays ?
    Ex : si je sélectionne la 3ème ligne, j'obtiens :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Pays Ville
    FR   33.000
    ES   25.000
    Espérant avoir été assez explicite.

  2. #2
    Membre éclairé
    Homme Profil pro
    Ingénieur de recherche
    Inscrit en
    Janvier 2012
    Messages
    325
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur de recherche
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2012
    Messages : 325
    Points : 888
    Points
    888
    Par défaut
    Une façon de faire parmis d'autres :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Reduce(rbind,by(DF,DF['Pays'],function(df){cbind(df,n=1:nrow(df))}))
    Après il suffit de filtrer avec la nouvelle colonne.

  3. #3
    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 autre manière de procéder en ayant recours au package "dplyr" (ici sélection de la 2ème ligne pour chaque pays) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    require(dplyr)
     
    group_by(DF, Pays) %>% mutate(n = 1:n()) %>% filter(n == 2) %>% select(Pays, Ville)

    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.

  4. #4
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Allez, encore une autre solution, avec le package data.table :
    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
    library(data.table)
    test <- data.frame(Pays = c("FR", "FR", "FR", "ES", "ES", "ES", "ES"), Ville = c(100,75,33,49,42,25,18))
     
    test
      Pays Ville
    1   FR   100
    2   FR    75
    3   FR    33
    4   ES    49
    5   ES    42
    6   ES    25
    7   ES    18
     
    dt <- data.table(test)
     
    dt
      Pays Ville
    1   FR   100
    2   FR    75
    3   FR    33
    4   ES    49
    5   ES    42
    6   ES    25
    7   ES    18
     
    n <- 3 #ici, on fixe la valeur de n
     
    dt[, .SD[n], by = Pays]
     
       Pays Ville
    1:   FR    33
    2:   ES    25
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

Discussions similaires

  1. Réponses: 5
    Dernier message: 08/11/2010, 17h50
  2. extraire la première ligne du buffer
    Par almofa237 dans le forum Général Java
    Réponses: 3
    Dernier message: 10/05/2010, 17h33
  3. Extraire multiligne vers ligne unique
    Par mandarinet dans le forum SQL
    Réponses: 7
    Dernier message: 24/03/2010, 16h10
  4. afficher, extraire la nième ligne d'un fichier
    Par italiasky dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 08/04/2007, 19h20
  5. Extraire intervale de lignes
    Par blacksnake dans le forum Langage
    Réponses: 2
    Dernier message: 15/03/2007, 18h46

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