superbog
XLDnaute Occasionnel
Bonjour,
J'ai diverses macro, chacune fonctionnant sur une feuille différente. Est il possible de créer une macro globale qui les lancerait en cascade?
voici deux exemples de macros à "joindre"
J'ai diverses macro, chacune fonctionnant sur une feuille différente. Est il possible de créer une macro globale qui les lancerait en cascade?
voici deux exemples de macros à "joindre"
Code:
Sub fact()
Dim i, DerLigBase, Lig As Integer
Dim dossier, sNomFeuille As String
Dim colFeuille As Collection
Dim rCelA As Range
Dim shAct As Worksheet
Dim FeuilleExist As Boolean
'Recherche de la dernière ligne
DerLigBase = Sheets("fact").Range("A999").End(xlUp).Row
Set colFeuille = New Collection
On Error Resume Next
'Boucle sur la plage de cellule
For Each rCelA In Sheets("fact").Range(Cells(2, 1), Cells(DerLigBase, 1))
colFeuille.Add rCelA, CStr(rCelA)
Next rCelA
'Recherche de la ligne et tri dans chaque feuille
For i = 2 To DerLigBase
dossier = Cells(i, 1).Text
Lig = Sheets(dossier).Range("U999").End(xlUp).Row
'Copie les valeurs si non barrées
With Sheets("fact").Cells(i, "B").Resize(, 7)
If Not .Cells(1).Font.Strikethrough Then '1ère valeur non barrée
Worksheets(dossier).Cells(Lig + 1, "U").Resize(, 7) = .Value
.Font.Strikethrough = True
End If
End With
Next i
MsgBox "opération effectuée"
End Sub
Sub HR()
Dim i, DerLigBase, Lig As Integer
Dim dossier, sNomFeuille As String
Dim colFeuille As Collection
Dim rCelA As Range
Dim shAct As Worksheet
Dim FeuilleExist As Boolean
'Recherche de la dernière ligne
DerLigBase = Sheets("HR").Range("A999").End(xlUp).Row
Set colFeuille = New Collection
On Error Resume Next
'Boucle sur la plage de cellule
For Each rCelA In Sheets("fact").Range(Cells(2, 1), Cells(DerLigBase, 1))
colFeuille.Add rCelA, CStr(rCelA)
Next rCelA
'Recherche de la ligne et tri dans chaque feuille
For i = 2 To DerLigBase
dossier = Cells(i, 1).Text
Lig = Sheets(dossier).Range("AA999").End(xlUp).Row
'Copie les valeurs si non barrées
With Sheets("HR").Cells(i, "B").Resize(, 7)
If Not .Cells(1).Font.Strikethrough Then '1ère valeur non barrée
Worksheets(dossier).Cells(Lig + 1, "AA").Resize(, 7) = .Value
.Font.Strikethrough = True
End If
End With
Next i
MsgBox "opération effectuée"
End Sub