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 une sous data.frame


Sujet :

R

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 73
    Points : 80
    Points
    80
    Par défaut Extraire une sous data.frame
    Bonjour R users,

    Je veux extraire une sous data.frame à partir d'une autre data.frame selon ma variable d'intérêt.
    Ex :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    VAR1  VAR2  VAR3
    MA    2     10g
    ME    3     50k
    AP    8     40l 
    NJ    1     63i
    MP    0     78y
    dans un autre fichier toto se trouve ma variable VAR1 (pas forcément la même longueur que la VAR3 dans la data frame). J'ai récupéré l'intersect entre le VAR3 de mon data.frame et de mon fichier toto.

    Maintenant, je veux extraire de la première data frame, une deuxième data frame qu'avec l'intersect de la variable VAR3??

    J'espère que je suis clair, merci par avance
    manoir

  2. #2
    Membre expert
    Avatar de pitipoisson
    Homme Profil pro
    Chercheur
    Inscrit en
    Septembre 2006
    Messages
    1 942
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Chercheur
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 942
    Points : 3 378
    Points
    3 378
    Par défaut
    Bonjour,

    Tu peux l'avoir directement avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    data[is.element(data$VAR3, toto$VAR1), ]
    ou bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    data[is.element(data$VAR3, <vecteur intersection>), ]
    Attention, s'il s'agit de facteurs il faut (puisque tu n'as pas forcément les même choses dans les deux, donc pas forcément les mêmes valeurs numériques pour les mêmes nivaux) faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    data[is.element(as.character(data$VAR3), as.character(<vecteur intersection>)), ]
    (pareil pour l'autre méthode)
    Forum LaTeX : pour des réponses rapides et appropriées, pensez à poster un
    ECM = Exemple (reproduit le problème) Complet (document compilable) Minimal (ne postez pas votre thèse !)

    Une solution vous convient ? N'oubliez pas le tag


    )><))))°>

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 73
    Points : 80
    Points
    80
    Par défaut
    Many thanks pitipoisson

    Manoir

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 73
    Points : 80
    Points
    80
    Par défaut
    Je voudrais récupérer les rs en commun entre deux fichiers Mat1 et Mat2

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Mat2<-read.delim(fichier1)
    Mat1<-read.delim(fichier2)
    M<-1:length(Mat2) # créer un ordre pour le vecteur rs
    Mat2<-data.frame(Mat2,M)
     
    colnames(Mat2)<-c("rs","ordre")
    inter<-intersect(Mat1$rs,Mat2) # les rs en commun entre les deux fichiers
    Mat3<-subset(Mat1, is.element(Mat1$rs,inter),) # récupérer la data.frame des rs en commun,
    Maintenant, je souhaite réordonner ma data.frame par rapport à l'ordre de mon fichier Mat2, c'est à dire garder l'ordre de Mat2$rs pour les rs en commun

    En vous remerciant
    M

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    73
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 73
    Points : 80
    Points
    80
    Par défaut
    Re bonjour,

    Ci dessous un exemple concret de ce que je souhaite faire,
    Chrom rs Position rs.1 order
    4 1 rs3094315 742429 MitoA10045G 1
    7 1 rs12562034 758311 MitoA10551G 2
    17 1 rs3934834 995669 MitoA11252G 3
    18 1 rs9442372 1008567 MitoA11468G 4
    19 1 rs3737728 1011278 MitoA12309G 6
    20 1 rs11260588 1011521 MitoA13106G 7
    21 1 rs6687776 1020428 MitoA13781G 9
    22 1 rs9651273 1021403 MitoA14234G 10
    23 1 rs4970405 1038818 MitoA14583G 11
    24 1 rs12726255 1039813 MitoA15245G 13

    C'est la data.frame finale, le vecteur rs et rs.1 sont exactement pareil sauf que sont pas classés dans le même ordre, la dernière colonne est l'ordre de rs.1.

    Je veux que rs =rs.1 en utilisant le vecteur ordre et pas order(rs)!!!

    Merci

Discussions similaires

  1. extraire une sous chaine d'un char*
    Par john123 dans le forum C
    Réponses: 7
    Dernier message: 13/10/2007, 00h20
  2. Extraire une sous-chaine
    Par tomy29 dans le forum Delphi
    Réponses: 5
    Dernier message: 25/07/2007, 12h16
  3. Réponses: 6
    Dernier message: 25/06/2007, 11h00
  4. Réponses: 2
    Dernier message: 09/09/2006, 10h40
  5. Extraire une sous-chaîne
    Par cenedra dans le forum C++
    Réponses: 3
    Dernier message: 07/08/2006, 10h02

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