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 :

Copie de cellule en fonction d'un critère


Sujet :

Macros et VBA Excel

  1. #21
    Membre expérimenté Avatar de laetitia
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    1 281
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 281
    Points : 1 512
    Points
    1 512
    Par défaut
    re,essai comme cela si j'ai compris j' ai pas simplifier!!

    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
    Sub Test()
    Dim f As Range, c As Variant
    Application.ScreenUpdating = False
    Sheets("Tableau").Activate
    With Sheets("Detail")
    For Each c In .Range("a7:a" & .Range("a65000").End(xlUp).Row)
    Set f = Sheets("Tableau").Range("f2:f" & Range("f65000").End(xlUp).Row).Find(c, LookIn:=xlValues, LookAt:=xlWhole)
    If Not f Is Nothing Then
    Rows(f.Row + 1).Insert Shift:=xlDown
    Cells(f.Row + 1, 1).Select
    Cells(f.Row + 1, 2) = Sheets("Detail").Range("a" & c.Row)
    Cells(f.Row + 1, 4) = Sheets("Detail").Range("b" & c.Row)
    Cells(f.Row + 1, 6) = Sheets("Detail").Range("c" & c.Row)
    Cells(f.Row + 1, 9) = Sheets("Detail").Range("d" & c.Row)
    Cells(f.Row + 1, 10) = Sheets("Detail").Range("e" & c.Row)
    End If: Next: End With
    End Sub

  2. #22
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 106
    Points : 40
    Points
    40
    Par défaut
    C'est quasiment ca,
    il y a juste le "code5" qui doit être soit dans la colonne I si = D et colonne J si=C

    Peux tu m'expliquer le code que tu as écrit, je ne veux pas recopier "bêtement" le code mais aussi le comprendre

    Peux t-on mettre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    If Sheets("Detail").Range("e" & c.Row) ="C" then
    Cells(f.Row + 1, 9) = Sheets("Detail").Range("e" & c.Row)
    Elseif 
    Cells(f.Row + 1, 10) = Sheets("Detail").Range("e" & c.Row)
    Encore Merci

  3. #23
    Membre expérimenté Avatar de laetitia
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    1 281
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 281
    Points : 1 512
    Points
    1 512
    Par défaut
    re , maintemant j' ai plus le temps je ferais la modif en fin d'apres midi plus explications que tu demande a+

  4. #24
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 106
    Points : 40
    Points
    40
    Par défaut
    ok biensur je comprends
    j'essaie de me dépatouiller,
    merci
    @+

  5. #25
    Membre expérimenté Avatar de laetitia
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    1 281
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 281
    Points : 1 512
    Points
    1 512
    Par défaut
    re, j'ai trouve 2 minutes j' ai supprimer le dessert

    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
    Sub Test()
    Dim f As Range, c As Variant
    Application.ScreenUpdating = False
    Sheets("Tableau").Activate
    With Sheets("Detail")
    For Each c In .Range("a7:a" & .Range("a65000").End(xlUp).Row)
    Set f = Sheets("Tableau").Range("f2:f" & Range("f65000").End(xlUp).Row).Find(c, LookIn:=xlValues, LookAt:=xlWhole)
    If Not f Is Nothing Then
    Rows(f.Row + 1).Insert Shift:=xlDown
    Cells(f.Row + 1, 2) = Sheets("Detail").Range("a" & c.Row)
    Cells(f.Row + 1, 4) = Sheets("Detail").Range("b" & c.Row)
    Cells(f.Row + 1, 6) = Sheets("Detail").Range("c" & c.Row)
    If Sheets("Detail").Range("e" & c.Row) = "D" Then
    Cells(f.Row + 1, 9) = Sheets("Detail").Range("e" & c.Row)
    Else
    Cells(f.Row + 1, 10) = Sheets("Detail").Range("e" & c.Row)
    End If: End If: Next: End With
    End Sub
    je boucle sur la feuille "detail" de a7 a la derniere non vide

    dans l'ex on cherche voiture
    je cherche sur la feuil tableau si une donnee correspond
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set f = Sheets("Tableau").Range("f2:f" & Range("f65000").End(xlUp).Row).Find(c, LookIn:=xlValues, LookAt:=xlWhole)
    si ok j'insere une ligne puis copy
    de nouveau voiture
    insere une ligne puis copy


    comme tu le dit find =variable vu qu'on insérent des lignes
    nouvelle recherche
    colonne f3,f4,ect jusque qu'il trouve une autre donnee dans l'exemple quad qui va se trouver en f9 ect...

  6. #26
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 106
    Points : 40
    Points
    40
    Par défaut
    Merci d'avoir trouver du temps pour me répondre, et pas seulement ces 2 min à la place du dessert...


    J'ai bien compris la 1ere partie de la macro
    La 2è partie est un peu plus obscure car je connaissait pas cette méthode

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Rows(f.Row + 1).Insert Shift:=xlDown
    Ni

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Cells(f.Row + 1, 2) = Sheets("Detail").Range("a" & c.Row)
    Encore merci à tous ceux qui ont particpé ( laëtitia)
    En espérant que ca puisse aider d'autre personne
    A bientôt

Discussions similaires

  1. [Toutes versions] Faire apparaître un message dans une cellule en fonction de différents critères
    Par niiiiiiiiiico dans le forum Macros et VBA Excel
    Réponses: 18
    Dernier message: 26/04/2013, 14h43
  2. [XL-2003] Adresse de cellules en fonction d'un critère sur leur contenu
    Par Yvanou dans le forum Excel
    Réponses: 4
    Dernier message: 09/07/2012, 17h50
  3. [XL-2003] Selectionner cellule en fonction de deux critères
    Par thoom dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 14/07/2011, 18h14
  4. [XL-2007] Surlignage automatique de cellules en fonction d'un critère
    Par panpulilu dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 16/06/2010, 23h27
  5. [XL-2003] Copie de cellule en fonction du numéro de lignes
    Par biquet25 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 06/04/2009, 19h34

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