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 :

supprimer deux lignes ayant le même intitulé et au moins une fois une valeur positive non nulle


Sujet :

R

  1. #1
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Février 2015
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Tarn et Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2015
    Messages : 15
    Points : 11
    Points
    11
    Par défaut supprimer deux lignes ayant le même intitulé et au moins une fois une valeur positive non nulle
    Bonjour,

    Alors j'ai de nouveau un problème.

    J'aimerais des lignes où la valeur de la colonne X est différente de 0.
    Or, mon tableau est en deux parties/périodes. Une période 1 et une période 2 (en lignes).
    Et du coup, j'aimerais supprimer les lignes à la fois dans la période 1 et dans la période 2 si jamais la colonne X est au moins une fois différente de 0.

    J'ai beau réfléchir à des boucles ou avec la fonction which, etc., je n'arrive pas à intégrer le fait de supprimer à la fois dans la période 1 et dans la période 2.

    Si ce n'est pas clair voilà un exemple:

    ligne periode X
    1 1 0
    2 1 10
    3 1 0
    1 2 0
    2 2 0
    3 2 0

    j'aimerais obtenir:

    ligne periode X
    1 1 0
    3 1 0
    1 2 0
    3 2 0

    et non:

    ligne periode X
    1 1 0
    3 1 0
    1 2 0
    2 2 0
    3 2 0

    Ainsi les lignes numérotées 2 ont été supprimées car la ligne 2 de la période 1 contenait un 10 dans la colonne X.

    Je suppose que c'est une ligne toute bête mais je ne trouve réellement pas ce qu'il faut faire.

    Un peu d'aide?

    Merci beaucoup!

  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
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    df=data.frame(ligne=c(1,2,3,1,2,3),periode=c(1,1,1,2,2,2),X=c(0,10,0,0,0,0))
    max_ligne=unlist(as.list(by(df$X,df$ligne,max)))
    df[max_ligne[as.character(df$ligne)]==0,]

Discussions similaires

  1. Utilisation de deux classes ayant le même nom
    Par Oosoos dans le forum Langage
    Réponses: 1
    Dernier message: 29/12/2010, 17h40
  2. Différencier deux processeurs ayant le même jeu d'instruction
    Par tashka dans le forum x86 32-bits / 64-bits
    Réponses: 14
    Dernier message: 03/09/2010, 12h18
  3. Réponses: 23
    Dernier message: 20/05/2009, 12h47
  4. numéroter les lignes ayant la même valeur dans une requête
    Par raiamanu dans le forum Requêtes et SQL.
    Réponses: 14
    Dernier message: 12/10/2007, 10h49
  5. [VBA-E] : somme de deux lignes ayant des positions variables
    Par johnmakina dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 23/01/2007, 16h47

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