Macro pour somme dans première cellule vide
Fermé
Aud1591
-
17 déc. 2014 à 20:19
ThauTheme Messages postés 1442 Date d'inscription mardi 21 octobre 2014 Statut Membre Dernière intervention 29 juillet 2022 - 18 déc. 2014 à 18:16
ThauTheme Messages postés 1442 Date d'inscription mardi 21 octobre 2014 Statut Membre Dernière intervention 29 juillet 2022 - 18 déc. 2014 à 18:16
A voir également:
- Macro pour somme dans première cellule vide
- Formule somme excel colonne - Guide
- Aller à la ligne dans une cellule excel - Guide
- Somme si couleur - Guide
- Telecharger macro convertir chiffre en lettre excel - Télécharger - Tableur
- Supprimer page word vide - Guide
2 réponses
ThauTheme
Messages postés
1442
Date d'inscription
mardi 21 octobre 2014
Statut
Membre
Dernière intervention
29 juillet 2022
160
18 déc. 2014 à 01:20
18 déc. 2014 à 01:20
Bonsoir Aud, bonsoir le forum,
J'ai pour habitude de commenter mes codes mais là il est trop tard et j'ai la flemme. Je te les livre bruts (mais testés)...
J'ai pour habitude de commenter mes codes mais là il est trop tard et j'ai la flemme. Je te les livre bruts (mais testés)...
Sub Macro1() Dim DL As Integer Dim TC As Variant Dim I As Integer Dim TLV() As Integer Dim J As Integer DL = Cells(Application.Rows.Count, 1).End(xlUp).Row TC = Range("A1:B" & DL) ReDim Preserve TLV(J) TLV(J) = -1: J = J + 1 For I = 1 To UBound(TC, 1) If TC(I, 1) = "" Then ReDim Preserve TLV(J) TLV(J) = I - 1 J = J + 1 End If Next I ReDim Preserve TLV(J) TLV(J) = DL For J = 1 To UBound(TLV) Cells(TLV(J) + 1, 1).Value = "Total" Cells(TLV(J) + 1, 2).Value = Application.WorksheetFunction.Sum(Range(Cells(TLV(J - 1) + 2, 2), Cells(TLV(J), 2))) Cells(TLV(J) + 1, 1).Resize(1, 2).Font.Bold = True Next J End Sub
pijaku
Messages postés
12263
Date d'inscription
jeudi 15 mai 2008
Statut
Modérateur
Dernière intervention
4 janvier 2024
2 751
18 déc. 2014 à 08:16
18 déc. 2014 à 08:16
Bonjour Aud, ThauTheme, le forum,
Excusez l'incruste...
Une variante :
Excusez l'incruste...
Une variante :
Sub Aud() Dim Tb(), DL As Long, i As Long, Somme As Double Const PremLigne As Integer = 1 ' à adapter = 1ère ligne, ici A1 'collecte des données DL = Range("A" & Rows.Count).End(xlUp).Row Tb = Range("A" & PremLigne & ":B" & DL) 'boucle sur les données For i = LBound(Tb, 1) To UBound(Tb, 1) 'si Ai est vide alors If Tb(i, 1) = "" Then Tb(i, 1) = "Total" 'Ai = "TOTAL" Tb(i, 2) = Somme 'Bi = Somme Somme = 0 'On réinitialise la somme Else 'sinon, si Ai non vide Somme = Somme + Tb(i, 2) ' on fait la somme des B End If Next i 'restitution des données Range("A" & PremLigne).Resize(UBound(Tb), 2) = Tb 'sans oublier la dernière somme Range("A" & DL + 1) = "Total": Range("B" & DL + 1) = Somme End Sub
ThauTheme
Messages postés
1442
Date d'inscription
mardi 21 octobre 2014
Statut
Membre
Dernière intervention
29 juillet 2022
160
18 déc. 2014 à 08:57
18 déc. 2014 à 08:57
Bonjour Pikaju,
On n'excuse pas l'incruste... On l'apprécie !
On n'excuse pas l'incruste... On l'apprécie !
pijaku
Messages postés
12263
Date d'inscription
jeudi 15 mai 2008
Statut
Modérateur
Dernière intervention
4 janvier 2024
2 751
>
ThauTheme
Messages postés
1442
Date d'inscription
mardi 21 octobre 2014
Statut
Membre
Dernière intervention
29 juillet 2022
Modifié par pijaku le 18/12/2014 à 11:29
Modifié par pijaku le 18/12/2014 à 11:29
Salut ThauTheme,
Bon, puisque tu le prends comme ça ;-)
Une variante "rigolote" s'impose :
Bon, puisque tu le prends comme ça ;-)
Une variante "rigolote" s'impose :
Sub AUD() Dim Adress() As String Adress = Split("$B$1," & Range("B1:B" & Cells(Application.Rows.Count, 1).End(xlUp).Row).SpecialCells(xlCellTypeBlanks).Offset(1, 0).Address & ",$B$" & Cells(Application.Rows.Count, 1).End(xlUp).Row + 2, ",") For i = 0 To UBound(Adress) - 1 Range(Adress(i + 1)).Offset(-1, -1) = "TOTAL" Range(Adress(i + 1)).Offset(-1, 0) = Evaluate("SUM(" & Adress(i) & ":" & Range(Adress(i + 1)).Offset(-1, 0).Address & ")") Next i End Sub
ThauTheme
Messages postés
1442
Date d'inscription
mardi 21 octobre 2014
Statut
Membre
Dernière intervention
29 juillet 2022
160
18 déc. 2014 à 12:07
18 déc. 2014 à 12:07
Arf !
pijaku
Messages postés
12263
Date d'inscription
jeudi 15 mai 2008
Statut
Modérateur
Dernière intervention
4 janvier 2024
2 751
>
ThauTheme
Messages postés
1442
Date d'inscription
mardi 21 octobre 2014
Statut
Membre
Dernière intervention
29 juillet 2022
18 déc. 2014 à 12:26
18 déc. 2014 à 12:26
Arf??
Je suis sur que l'on peut encore trouver d'autres façons de faire. Non?
Je suis sur que l'on peut encore trouver d'autres façons de faire. Non?
ThauTheme
Messages postés
1442
Date d'inscription
mardi 21 octobre 2014
Statut
Membre
Dernière intervention
29 juillet 2022
160
>
pijaku
Messages postés
12263
Date d'inscription
jeudi 15 mai 2008
Statut
Modérateur
Dernière intervention
4 janvier 2024
18 déc. 2014 à 18:16
18 déc. 2014 à 18:16
Arf = étonnement admiratif..
Oui il en existe sûrement d'autres...
Oui il en existe sûrement d'autres...