Problème pour faire fonctionner une boucle For/If
Résolu
lauraSoe
Messages postés
29
Date d'inscription
Statut
Membre
Dernière intervention
-
Polux31 Messages postés 6917 Date d'inscription Statut Membre Dernière intervention -
Polux31 Messages postés 6917 Date d'inscription Statut Membre Dernière intervention -
Bonjour, je suis stagiaire et on m'a demandé de réaliser une Macro sur Excel (j'en avais jamais fait jusqu'à présent)
Voici mon problème:
Je voudrai vérifier les dates de deux colonnes différentes B et E sur la même feuille.
Si elles sont identiques alors je fais un copier/coller de la valeur de F (sur la même ligne de E) sur la colonne C (à côté de la valeur de B correspondante).
Sinon la date de Ei n'existe pas dans B alors je fais un Copier/Coller de Ei et Fi sur la première ligne vide de la colonne B.
Je ne sais pas si j'ai été très claire.
Voici le code que j'ai fait (Ils disent qu'il y a un problème avec If que je n'arrive pas à résoudre).
J'ai déjà cherché pas mal depuis hier après-midi, je n'ai pas trouvé la réponse qu'il me fallait! (Au secours! vous êtes mon dernier espoir!! :) )
Merci beaucoup d'avance de l'aide que vous pourrez m'apporter,
Bonne journée.
Voici mon problème:
Je voudrai vérifier les dates de deux colonnes différentes B et E sur la même feuille.
Si elles sont identiques alors je fais un copier/coller de la valeur de F (sur la même ligne de E) sur la colonne C (à côté de la valeur de B correspondante).
Sinon la date de Ei n'existe pas dans B alors je fais un Copier/Coller de Ei et Fi sur la première ligne vide de la colonne B.
Je ne sais pas si j'ai été très claire.
Voici le code que j'ai fait (Ils disent qu'il y a un problème avec If que je n'arrive pas à résoudre).
J'ai déjà cherché pas mal depuis hier après-midi, je n'ai pas trouvé la réponse qu'il me fallait! (Au secours! vous êtes mon dernier espoir!! :) )
Dim i As Byte
Dim j As Byte
Dim derlig As Integer
derlig = Sheets("MACRO").Range("E65536").End(xlUp).Row
derlig2 = Sheets("MACRO").Range("B65536").End(xlUp).Row
For j = 2 To derlig
If Bi = Ej = True Then ActiveWindow.SmallScroll Down:=-12
Range("Fi").Select
Application.CutCopyMode = False
Selection.Copy
ActiveWindow.SmallScroll Down:=0
Range("C(i+1)").Select
ActiveSheet.Paste
End If
If Bi = Ej = False Then Do
ActiveWindow.SmallScroll Down:=-18
Range("Ej:Fj").Select
Selection.Copy
ActiveWindow.SmallScroll Down:=12
Range("derlig2").Select
ActiveSheet.Paste
End If
Merci beaucoup d'avance de l'aide que vous pourrez m'apporter,
Bonne journée.
A voir également:
- Problème pour faire fonctionner une boucle For/If
- Downloader for pc - Télécharger - Téléchargement & Transfert
- Comment faire fonctionner le chromecast - Guide
- Idm for mac - Télécharger - Téléchargement & Transfert
- Copytrans heic for windows - Télécharger - Visionnage & Diaporama
- Instagram for pc - Télécharger - Divers Communication
4 réponses
Bonjour,
Le problème vient de la syntaxe de tes If :
Le problème vient de la syntaxe de tes If :
If Bi = Ej = True Thenn'est pas correct. Il faut faire :
If Bi = Ej Then. Si la condition est vraie Alors il exécute le code jusqu'à la fin du If.
C'est surtout la boucle qui déconne je pense.
Non, tu n'as pas bien lu mon post ... j'avais pourtant dit : syntaxe de tes If .
Tu as modifié le premier If mais pas le 2ème ...
Il faut faire:
Si Bi = Ej Alors fait
' ... le code qui va bien si la condition est vraie
Sinon fait
' ... le code qui va bien si la condition est fausse
Fin Si
Tu peux également supprimer tous les
Non, tu n'as pas bien lu mon post ... j'avais pourtant dit : syntaxe de tes If .
Tu as modifié le premier If mais pas le 2ème ...
Il faut faire:
Si Bi = Ej Alors fait
' ... le code qui va bien si la condition est vraie
Sinon fait
' ... le code qui va bien si la condition est fausse
Fin Si
Tu peux également supprimer tous les
ActiveWindow.ScrollColumnqui ne servent à rien.
Hum... Voilà j'ai corrigé comme vous avez dit, mais c'est toujours pareil "Erreur de compilation: else sans bloc If".
Dim i As Byte
Dim j As Byte
Dim derlig As Integer
derlig = Sheets("MACRO").Range("E65536").End(xlUp).Row
derlig2 = Sheets("MACRO").Range("B65536").End(xlUp).Row
For j = 2 To derlig
If Bi = Ej Then Range("Fi").Select
Selection.Copy
Range("C(i+1)").Select
ActiveSheet.Paste
Else: Range("Ej:Fj").Select
Selection.Copy
Range("derlig2").Select
ActiveSheet.Paste
End If
Dim i As Byte
Dim j As Byte
Dim derlig As Integer
derlig = Sheets("MACRO").Range("E65536").End(xlUp).Row
derlig2 = Sheets("MACRO").Range("B65536").End(xlUp).Row
For j = 2 To derlig
If Bi = Ej Then Range("Fi").Select
Selection.Copy
Range("C(i+1)").Select
ActiveSheet.Paste
Else: Range("Ej:Fj").Select
Selection.Copy
Range("derlig2").Select
ActiveSheet.Paste
End If
Il y a des erreurs de syntaxe ...
Que sont Bi et Ej ? Des cellules ? Si oui
Que sont Bi et Ej ? Des cellules ? Si oui
If Range("B" & i).Value = Range("E" & j).Value Then Range("F" & i).Copy Destination:=Range("C" & i +1) Else Range("E" & j & ":F" & j).Copy Destination:=Range("B" & derlig2) End If
Oui ce sont des cellules, merci!
Alors j'ai remplacé, et il y avait un problème "Methode Range de l'objet global a échoué"
J'ai cherché , apparemment ça vient qu'on a pas précisé où on le fait du coup j'ai rajouté Worksheet. avant le Range.
maintenant nouveau truc, ils marquent erreur 424 objet requis. Je pas comment on peut solutionner le problème...
(J'ai vraiment du mal, désolé et merci de votre patience :) )
Alors j'ai remplacé, et il y avait un problème "Methode Range de l'objet global a échoué"
J'ai cherché , apparemment ça vient qu'on a pas précisé où on le fait du coup j'ai rajouté Worksheet. avant le Range.
maintenant nouveau truc, ils marquent erreur 424 objet requis. Je pas comment on peut solutionner le problème...
(J'ai vraiment du mal, désolé et merci de votre patience :) )
J'ai initialisé je pense, ça donne ça?
Enfin du coup au niveau du débogage ça marche, mais quand j'exécute la macro ça marche pas (désespoir total)
ça a pas copier les éléments de E sur la colonne C ni même les dates manquantes...
Dim i As Integer
Dim j As Integer
Dim derlig As Integer
derlig = Sheets("MACRO").Range("E65536").End(xlUp).Row
derlig2 = Sheets("MACRO").Range("B65536").End(xlUp).Row
i = 2
For j = 2 To derlig
If Range("B" & i).Value = Range("E" & j).Value Then
Range("F" & i).Copy Destination:=Range("C" & i + 1)
Else
Range("E" & j & ":F" & j).Copy Destination:=Range("B" & derlig2)
End If
Enfin du coup au niveau du débogage ça marche, mais quand j'exécute la macro ça marche pas (désespoir total)
ça a pas copier les éléments de E sur la colonne C ni même les dates manquantes...
Tu dis : ça a pas copier les éléments de E sur la colonne C
A aucun moment tu demandes de le faire dans le code !!!
Moi je lis :
Si ma cellule Bx est égale à Ey Alors je copie la cellule Fx dans la cellule C x+1 Sinon je copie la plage de cellule Ey:Fy sur la dernière ligne de la colonne B.
Pourquoi mettre i en variable si on copie toujours la cellule "F2" pour la copier en "C3" ??? Ne manque-t-il pas une incrémentation de i ?
A aucun moment tu demandes de le faire dans le code !!!
Moi je lis :
Si ma cellule Bx est égale à Ey Alors je copie la cellule Fx dans la cellule C x+1 Sinon je copie la plage de cellule Ey:Fy sur la dernière ligne de la colonne B.
Pourquoi mettre i en variable si on copie toujours la cellule "F2" pour la copier en "C3" ??? Ne manque-t-il pas une incrémentation de i ?
Bonjour,
excusez l'incruste
Excuses moi Polux, je n'avais pas rafraichi
si résolu le problème du compteur "i"
j'aurais écrit
remarque: supprimer tous les
ActiveWindow.ScrollColumn=xxx inutiles et ralentisseurs de la macro
excusez l'incruste
Excuses moi Polux, je n'avais pas rafraichi
si résolu le problème du compteur "i"
j'aurais écrit
Dim i As Integer, j As Integer
Dim Derlig As Integer, Ligvide As Integer
Application.ScreenUpdating = False
With Sheets("MACRO")
Derlig = .Range("E65536").End(xlUp).Row
For j = 3 To Derlig
If .Range("B" & i) = .Range("E" & j) Then
.Range("C" & i + 1) = .Range("F" & i).Value
Else
Ligvide = .Range("B65536").End(xlUp).Row + 1
.Cells(Ligvide, "B").Resize(1, 2) = .Range(.Cells(j, "E"), .Cells(j, "E")).Value
End If
End With
Next
remarque: supprimer tous les
ActiveWindow.ScrollColumn=xxx inutiles et ralentisseurs de la macro
With Sheets("MACRO")
Derlig = .Range("E65536").End(xlUp).Row
For j = 3 To Derlig
If .Range("B" & i) = .Range("E" & j) Then
.Range("C" & i + 1) = .Range("F" & i).Value
Else
Ligvide = .Range("B65536").End(xlUp).Row + 1
.Cells(Ligvide, "B").Resize(1, 2) = .Range(.Cells(j, "E"), .Cells(j, "E")).Value
End If
Next
End With
Comme je n'ai pas pu tester j'ai fais un bug excuse moi
With........end with
Ce la s'appelle un bloc, cad que entre le début et la fin du bloc tout ce qui précédé du point appartient au bloc, per ex:
With sheets("macro"):
tu peux voir que toutes les cellules de de la feuille sont précédés d'un point; c'est l'équivalent de sheets("macro").range("machin")
L'avantage est une écriture + claire, une fiabilité du traitement
Avec wirth sheets("truc") tu n'as plus besoin de faire des "select" ou "activate" toujours très lents
(les select-selection sont à éviter en VBA)
un tuto très complet mais qui ne se lit pas comme un roman policier:
https://bidou.developpez.com/article/VBA/
cela te permettra de passer de l'enregistreur de macros au VBA
Derlig = .Range("E65536").End(xlUp).Row
For j = 3 To Derlig
If .Range("B" & i) = .Range("E" & j) Then
.Range("C" & i + 1) = .Range("F" & i).Value
Else
Ligvide = .Range("B65536").End(xlUp).Row + 1
.Cells(Ligvide, "B").Resize(1, 2) = .Range(.Cells(j, "E"), .Cells(j, "E")).Value
End If
Next
End With
Comme je n'ai pas pu tester j'ai fais un bug excuse moi
With........end with
Ce la s'appelle un bloc, cad que entre le début et la fin du bloc tout ce qui précédé du point appartient au bloc, per ex:
With sheets("macro"):
tu peux voir que toutes les cellules de de la feuille sont précédés d'un point; c'est l'équivalent de sheets("macro").range("machin")
L'avantage est une écriture + claire, une fiabilité du traitement
Avec wirth sheets("truc") tu n'as plus besoin de faire des "select" ou "activate" toujours très lents
(les select-selection sont à éviter en VBA)
un tuto très complet mais qui ne se lit pas comme un roman policier:
https://bidou.developpez.com/article/VBA/
cela te permettra de passer de l'enregistreur de macros au VBA
Je viens de corriger le problème maintenant ils marquent: Erreur de compilation: End if sans bloc If.
j'ai regardé dans d'autres post mais j'ai toujours pas compris ce que ça voulait dire :/
C'est surtout la boucle qui déconne je pense.
Merci.