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

Macros et VBA Excel Discussion :

copier des cellules d'une feuille dans une autres sous condition


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    14
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Avril 2007
    Messages : 14
    Points : 5
    Points
    5
    Par défaut copier des cellules d'une feuille dans une autre sous condition
    J'ai une macro qui copie colle les valeurs d'une ligne sur les suivantes toutes les secondes:celle là elle marche

    Ensuite mon objectif est que quand une valeur dépasse le maximum des 10 lignes précédentes, la ligne en question soit collée dans une autre feuille

    J'ai essayé avec If activecell.value > Application.WorksheetFunction.Max ...then
    mais ca me copiait toutes les lignes et pas seulement celles ki depassaient le max

    J'ai essayé select case et là ca me coipie plus rien dans l'autre feuille...

    J'ai ensuite séparé la macro en 2
    D'une part dans la 1ere une macro ki prend des valeurs de la 1ere feuille vers la seconde
    D'autre part dans la 2eme macro , le copier coller de toutes les valeurs à chaque seconde sur la ligne suivante et un select case ki utilise la 1ere macro si le max est depassé (pour savoir si le max est depassé j'ai essayé avec la formule max dans excel puis un if(A3>B3;1;0) (A3 etant la valeur initiale et B3 le max) et ensuite je demande juste à ma macro de verifier que ma cellule A3=1 ou ="1" mais y a rien à faire ca marche pas

    Aidez moi please j'en peux plus

    Merci d'avance

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    491
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 491
    Points : 542
    Points
    542
    Par défaut
    bonjour
    essaye avec une boucle qui va rechercher si ta derniere valeur copiée est sup
    au 10 derniere
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub essais()
    Dim i As Integer
    Dim val
    val = ActiveCell.Value 'ici la valeur de cellule que tu veux comparer
    For i = 1 To 10
    If val > Cells(11 - i, 1).Value Then
    'ton code
    MsgBox val & "supérieur au 10 dernieres valeures "
    End If
    Next i

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    14
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Avril 2007
    Messages : 14
    Points : 5
    Points
    5
    Par défaut
    Non ca ne marche toujours pas , mais es tu sûr de ton :

    If val > Cells(11 - i, 1).Value Then

    le "Cells(11 - i, 1).Value " renvoie t il à la plage des 10 cellules au dessus ou renvoie t il à la cellule 11-i lignes en dessous et une colonne aprés ??

    J'ai déjà eu ce doute quand j'ai voulu selectionner une plage de cellule avec activecell.offset

    Merci pour ton aide

  4. #4
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 546
    Points
    15 546
    Par défaut
    Regarde
    Pour la condition, tu mets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If (la condition) then ....

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    14
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Avril 2007
    Messages : 14
    Points : 5
    Points
    5
    Par défaut
    if ... then

    Tu penses bien que c'est la 1ere chose ke j'ai essayé

    ps:ton lien ne fonctionne pas

    Merci quand même

    pps:je posterai mon code demain, ca sera + facile de m'aider

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    491
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 491
    Points : 542
    Points
    542
    Par défaut
    bonjour
    avec la boucle for i =1 to 10
    le "Cells(11 - i, 1).Value " renvoie la plage des 10 cellules au dessus
    donc la plage de cellule("a1:a10")

  7. #7
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 546
    Points
    15 546
    Par défaut
    olivertwist m'ayant chaudement remercié par mp pour la clarté de ma réponse précédente...
    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
    Sub ChercherLeMax()
    Dim Fl1 As Worksheet
    Dim Fl2 As Worksheet
    Dim Plage As Range
    Dim NoLigne As Integer
    Set Fl1 = Worksheets("Feuil1")
    Set Fl2 = Worksheets("Feuil3")
     
        Set Plage = Fl1.Range("D11:D" & Range("D65535").End(xlUp).Row)
        For Each Cell In Plage
            If Cell.Value > Application.WorksheetFunction.Max(Cell.Offset(-1, 0), Cell.Offset(-10, 0)) Then
                NoLigne = NoLigne + 1
                Cell.EntireRow.Copy Destination:=Fl2.Cells(NoLigne, 1)
            End If
        Next
    End Sub
    En espérant que ça t'aide
    A+

    NB - Pour mon exemple, j'ai pris la colonne D... tu sauras adapter ?

Discussions similaires

  1. copier une table d'une BDD dans une table d'une autre BDD
    Par faniette dans le forum C++Builder
    Réponses: 2
    Dernier message: 15/05/2013, 10h17
  2. [XL-2007] Afficher une checkbox dans une feuille si une checkbox d'une autre feuille est cochée
    Par JessieCoutas dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 18/08/2009, 13h35
  3. [E-00] Syntaxe pour insérer une ligne ou une colonne dans une feuille
    Par Benjycool dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 02/02/2009, 09h27
  4. Réponses: 4
    Dernier message: 02/07/2008, 11h32
  5. Insérer une feuille dans une feuille
    Par PsychedeChed dans le forum Excel
    Réponses: 2
    Dernier message: 07/02/2008, 14h01

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