Macro en boucle qui ne fonctionne pas

Steugeu -  
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour,

Je suis sur un tableau Excel, et je souhaiterai créer une marco en boucle pour que celle ci me fasse des calculs à partir de certaines cellules.
En gros, j'ai des chiffres dans ma colonne A sur les lignes 3 à15.
J'ai mis une condition pour démarrer qui est : si A3 est > 1 alors il me fait des calculs sur les colonnes B3, C3, D3 etc etc.... et en fait je n'arrive pas a faire la boucle pour que cette formule se reproduise sur les lignes en dessous.
QQ'un pourrait-il m'aider ?
Merci beaucoup !!

A voir également:

13 réponses

melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
oui une seule cellule qui s'appelle totale.

Au lieu de Do While i< range("total").row
écrit :
Do While i<= range("total").row
1
Steugeu
 
OK!! Là c'est nickel !! Merci énormément !!!!!
Serieux tu assures !!!!!!
0
Steugeu
 
Heuuuu..... Mélaniiiie.......... Petite question !
Comment faire pourque : au lieu d'arrêter la macro à "TOTAL", ben en fait elle s'arrête
quand la case est vide ?
Parce qu'en fait, là tout est nickel, mais par exemple si j'insère une ligne en +, du coup il s'arrête à TOTAL !
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
re,

remplaceDo While i< range("total").row par
Do While selection<>""
1
Steugeu
 
OK nickel il s'arrête bien à partir du moment ou la case est vide !
MAIS !! Du coup comme j'ai viré la zone de nom "TOTAL" , il indique "#NOM?"
puisque dans ma macro, je lui ai donné comme calcul :
ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
0
Steugeu
 
En fait, pour etre + clair, je voudrai remplacer "TOTAL" par la somme de toutes les lignes !
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
Bonjour,

Pour faire une boucle sur des lignes
for i =3 to 15
'tu mets ce que ca fait sur ta colonne
next i
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
Bonjour,

Pour faire une boucle sur des lignes
for i =3 to 15
'tu mets ce que ca fait sur ta colonne
'i est ta variable de ligne donc tes cellules doivent être cells(i,1) pour taligne 1ère colonne
'cells(i,2) pour ta ligne et 2e colonne...
next i

Si tu as du mal mets ton code en entier et je t'aiderais
0
Steugeu
 
Bonjour Mélanie, déjà merci pour ta réponse :)
Voici donc mon chef d'oeuvre :)

'
Do
ActiveCell.Offset(12, B).Select


If ActiveCell.Value > 1 Then

ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
Range("D12").Select
ActiveCell.FormulaR1C1 = "=ROUND(RC[-2]*R[-1]C/TOTAL,2)"
Range("E12").Select
ActiveCell.FormulaR1C1 = "=RC[-3]*R[-1]C/TOTAL"
Range("F12").Select
ActiveCell.FormulaR1C1 = "=RC[-3]-RC[-1]"
Range("G12").Select
ActiveCell.FormulaR1C1 = "=RC[-3]"
Range("C13").Select


End If
Loop Until ActiveCell.Value = 0



End Sub


Mon soucis c'est qu'en fait le nombre de ligne peut varier ! là tu vois j'ai mis de la ligne 3 a 15 mais ça peut etre + ou - que ça !!
Ca doit pas etre compliqué je pense !! C'est juste de la logique !!
A partir de la cellule C12, je fais des calculs sur les cellules D12, E12 F12 et G12.
Après cela je veux que ma macro (incluant tous mes cacluls) se répète sur les lignes en dessous (donc à partir de C13 poure les cellules D13 E13 etc etc) !!!
0
Steugeu
 
As tu essayé de me répondre ?
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
Bonjour,

il faut revoir tout ton code :

for i =3 to 15
cells(i,1).select

Do cells(i,1)=0


If ActiveCell.Value > 1 Then

ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
cells(i,4).select
ActiveCell.FormulaR1C1 = "=ROUND(RC[-2]*R[-1]C/TOTAL,2)"
cells(i,5).select
ActiveCell.FormulaR1C1 = "=RC[-3]*R[-1]C/TOTAL"
cells(i,6).select
ActiveCell.FormulaR1C1 = "=RC[-3]-RC[-1]"
cells(i,7).selecr
ActiveCell.FormulaR1C1 = "=RC[-3]"

End If
Loop

next i

Ca marche?
0
Steugeu
 
Nan ça marche pas !! :(
Il m'indique que j'ai un soucis avec : If ActiveCell.Value > 1 Then
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
for i =3 to 15
cells(i,1).select

Do cells(i,1)=0


If ActiveCell.Value > 1 Then

ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
cells(i,4).select
ActiveCell.FormulaR1C1 = "=ROUND(RC[-2]*R[-1]C/TOTAL,2)"
cells(i,5).select
ActiveCell.FormulaR1C1 = "=RC[-3]*R[-1]C/TOTAL"
cells(i,6).select
ActiveCell.FormulaR1C1 = "=RC[-3]-RC[-1]"
cells(i,7).select
ActiveCell.FormulaR1C1 = "=RC[-3]"

End If
Loop

next i
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
pardon

remplace : If ActiveCell.Value > 1 Then

par If selection.value > 1
0
Steugeu
 
Voilà ce que je viens de faire, j'ai supprimé le DO cells(i,1)=0
parce que du coup il me remplace le montant dans la cellule par 0.

For i = 12 To 30
Cells(i, 2).Select

Do


If Selection.Value > 1 Then
Cells(i, 3).Select
ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
Cells(i, 4).Select
ActiveCell.FormulaR1C1 = "=ROUND(RC[-2]*R[-1]C/TOTAL,2)"
Cells(i, 5).Select
ActiveCell.FormulaR1C1 = "=RC[-3]*R[-1]C/TOTAL"
Cells(i, 6).Select
ActiveCell.FormulaR1C1 = "=RC[-3]-RC[-1]"
Cells(i, 7).Select
ActiveCell.FormulaR1C1 = "=RC[-3]"

End If
Loop

Next i

End Sub

Et du coup il me fait la macro en boucle...mais que sur la ligne 12 !
il descend pas !!
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
je ne suis pas bien réveillée :
for i =3 to 15
cells(i,1).select



If ActiveCell.Value > 1 Then

ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
cells(i,4).select
ActiveCell.FormulaR1C1 = "=ROUND(RC[-2]*R[-1]C/TOTAL,2)"
cells(i,5).select
ActiveCell.FormulaR1C1 = "=RC[-3]*R[-1]C/TOTAL"
cells(i,6).select
ActiveCell.FormulaR1C1 = "=RC[-3]-RC[-1]"
cells(i,7).select
ActiveCell.FormulaR1C1 = "=RC[-3]"

End If
next i
0
Steugeu
 
Ben je peux te dire que si tu es réveillée :) ça marche !! :)
Tu assures Mel' :) !!! Par conter, j'ai une dernière question et après j'arrêtes de t'embêter !!
Tu sais qd il fait les calculs, comment je dois faire pour qu'il prenne toujours la même cellule dans son calcul ? tu sais on met la lettre de la cellule entre $$
exemple $C$12.
Comment ça se manifeste dans une macro ça ?
Je les place ou dans ma formule ?

ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
Bonjour,
ca se manisfeste de la manière suivante.
exemple : si dans ton calcule, ca se base sur C2 :
ActiveCell.FormulaR1C1 = "=R2C3"
se base sur A4
ActiveCell.FormulaR1C1 = "=R4C1"

multiplier c2 par A4
ActiveCell.FormulaR1C1 = "=R2C3*R4C1"

R pour la ligne et C pour la colonne.
0
Steugeu
 
Ok ça marche bien là c'est nickel !!!!
Juste une dernière chose !! Ma dernieère cellule en bas, c'est le total (c'est d'ailleurs, comme tu as pu le constater repris dans les formule "TOTAL")
Comment faire pour qu'en fait la macro s'arrête qd il est arrivé à TOTAL, en fait je ne veuxpas qu'il me fasse de calcul arrivé sur cette cellule
0
Steugeu
 
NAN j'ai rien dit !! c'est bon en fait !!!! Je dois bien avoir le résultat !!! C'est Nickel !!!
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
Alors il faut modifier ton code :
i=3

cells(i,1).select
do while cells(i,1) <> "TOTAL"


If ActiveCell.Value > 1 Then

ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
cells(i,4).select
ActiveCell.FormulaR1C1 = "=ROUND(RC[-2]*R[-1]C/TOTAL,2)"
cells(i,5).select
ActiveCell.FormulaR1C1 = "=RC[-3]*R[-1]C/TOTAL"
cells(i,6).select
ActiveCell.FormulaR1C1 = "=RC[-3]-RC[-1]"
cells(i,7).select
ActiveCell.FormulaR1C1 = "=RC[-3]"

End If
i=i+1
cells(i,1).select
loop
0
Steugeu
 
Ok alors là moi je dis RESPECT !!
Si ensuite je fais une mise en forme des cellules via la macro (je vais rajouter des trucs comme quoi je veux 2 chiffres apres la virgule et les montants espacés, et aussi des bordures, est ce que je peux arrêter cette mise en forme à TOTAL ? c'est à dire ne pas aller + loin que TOTAL ?
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
Bien sur, il suffit de mettre ton code correspondant à la mise en forme entre le do et le loop.
0
Steugeu
 
Ca ne fonctionne plus !! Je ne sais aps pourquoi !!
Mais je pense que c'est à cause de "TOTAL" tu sais c'est pas écrit "TOTAL" dans la cellule, c'est juste que j'ai remplacé le nom de la cellule B23 par "TOTAL"

regarde la macro :

i = 12

Cells(i, 2).Select
Do While Cells(i, 2) = "TOTAL"


If ActiveCell.Value > 1 Then

ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
Cells(i, 4).Select
ActiveCell.FormulaR1C1 = "=ROUND(RC[-2]*R[-1]C/TOTAL,2)"
Cells(i, 5).Select
ActiveCell.FormulaR1C1 = "=RC[-3]*R[-1]C/TOTAL"
Cells(i, 6).Select
ActiveCell.FormulaR1C1 = "=RC[-3]-RC[-1]"
Cells(i, 7).Select
ActiveCell.FormulaR1C1 = "=RC[-3]"

End If

Range("C12:G12").Select
Selection.Borders(xlDiagonalDown).LineStyle = xlNone
Selection.Borders(xlDiagonalUp).LineStyle = xlNone
With Selection.Borders(xlEdgeLeft)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlEdgeTop)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlEdgeBottom)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlEdgeRight)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlInsideVertical)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlInsideHorizontal)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
Selection.NumberFormat = "#,##0.00"
Range("C12").Select


i = i + 1
Cells(i, 1).Select
Loop

End Sub
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
Re,
Ce code marche si tu as défini une plage de cellule comme étant total :


i = 12

Cells(i, 2).Select
Do While i< range("total").row


If ActiveCell.Value > 1 Then

ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
Cells(i, 4).Select
ActiveCell.FormulaR1C1 = "=ROUND(RC[-2]*R[-1]C/TOTAL,2)"
Cells(i, 5).Select
ActiveCell.FormulaR1C1 = "=RC[-3]*R[-1]C/TOTAL"
Cells(i, 6).Select
ActiveCell.FormulaR1C1 = "=RC[-3]-RC[-1]"
Cells(i, 7).Select
ActiveCell.FormulaR1C1 = "=RC[-3]"

End If

Range("C12:G12").Select
Selection.Borders(xlDiagonalDown).LineStyle = xlNone
Selection.Borders(xlDiagonalUp).LineStyle = xlNone
With Selection.Borders(xlEdgeLeft)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlEdgeTop)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlEdgeBottom)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlEdgeRight)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlInsideVertical)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlInsideHorizontal)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
Selection.NumberFormat = "#,##0.00"
Range("C12").Select


i = i + 1
Cells(i, 1).Select
Loop
0
Steugeu
 
ok là c'est bon ça refonctionne !! Qd tu me dis "une plage de cellule comme étant total"
si ce n'est qu'une seule cellule qui s'appelle total c'est bon ou pas ?
Parce que là du coup, il fait bien les calculs, mais s'arrête à "Total" sans faire le calcul sur cette ligne !
0
melanie1324 Messages postés 1504 Date d'inscription   Statut Membre Dernière intervention   155
 
i = 12

Cells(i, 2).Select
Do While cells(i,1)<> ""

If ActiveCell.Value > 1 Then

ActiveCell.FormulaR1C1 = "=RC[-1]*R[-1]C/TOTAL"
Cells(i, 4).Select
ActiveCell.FormulaR1C1 = "=ROUND(RC[-2]*R[-1]C/TOTAL,2)"
Cells(i, 5).Select
ActiveCell.FormulaR1C1 = "=RC[-3]*R[-1]C/TOTAL"
Cells(i, 6).Select
ActiveCell.FormulaR1C1 = "=RC[-3]-RC[-1]"
Cells(i, 7).Select
ActiveCell.FormulaR1C1 = "=RC[-3]"

End If

Range(cells(i,3),cells(i,7)).Select
Selection.Borders(xlDiagonalDown).LineStyle = xlNone
Selection.Borders(xlDiagonalUp).LineStyle = xlNone
With Selection.Borders(xlEdgeLeft)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlEdgeTop)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlEdgeBottom)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlEdgeRight)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlInsideVertical)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
With Selection.Borders(xlInsideHorizontal)
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
Selection.NumberFormat = "#,##0.00"

i = i + 1
Cells(i, 1).Select
Loop
cells(i,4).select
ActiveCell.FormulaR1C1 = "=SUM(R12C:R[-1]C)"
selection.select
ActiveWorkbook.Names("total").Delete
Selection.Name = "total"
0