XL 2016 Extraction x fois

  • Initiateur de la discussion Initiateur de la discussion patoq
  • Date de début Date de début
  • Mots-clés Mots-clés
    ns le

Boostez vos compétences Excel avec notre communauté !

Rejoignez Excel Downloads, le rendez-vous des passionnés où l'entraide fait la force. Apprenez, échangez, progressez – et tout ça gratuitement ! 👉 Inscrivez-vous maintenant !

patoq

XLDnaute Occasionnel
Bonjour le forum,

J'aimerais pouvoir accélérer une macro qui fonctionne mais devient lente sur une grande plage de données.
Dans le fichier joint, j'extrait 6 fois chaque code ( colonne I de la feuille Budget) dans l'onglet STJ .
J'ai mis une formule en colonne L et utilise un select case dessus pour ramener une identité unique.

Tout fonctionne à merveille mais la macro devient lente si le tableau source grossit.

Je pense que la macro est largement optimisable en passant par des tableaux, mais je n'est pas les compétences requises pour adapter mon code.

Merci de votre aide

Patrice
 

Pièces jointes

Bonsoir le fil, le forum

En attendant (non pas Godot) mais les tableaux
Une macro qui fait le job
VB:
Sub XFois()
Dim x As Long, l As Long
With Sheets("Budget")
    .Range("$A$1:$L$4499").AutoFilter Field:=12, Criteria1:="<>"
    .AutoFilter.Range.Columns(9).SpecialCells(xlCellTypeVisible).Copy Sheets("STJ").Range("A1")
    .ShowAllData
End With
Application.ScreenUpdating = False
With Sheets("STJ")
l = .Cells(Rows.Count, 1).End(xlUp).Row + 5
    For x = .Cells(Rows.Count, "A").End(xlUp).Row To 2 Step -1
    .Rows(x + 1).Resize(6 - 1).Insert
    .Rows(x).Resize(6).FillDown
   Next x
End With
End Sub
 
Bonjour le fil, le forum

Avec un petit bout de tableau c'est un peu plus rapide
VB:
Sub XFoisBis()
Dim t As Variant
With Sheets("Budget")
    .Range("$A$1:$L$4499").AutoFilter Field:=12, Criteria1:="<>"
    .AutoFilter.Range.Columns(9).SpecialCells(12).Copy Sheets("STJ").Range("A1")
    .ShowAllData
    .AutoFilterMode = False
End With
Application.CutCopyMode = False
Application.ScreenUpdating = False
With Sheets("STJ")
    t = .UsedRange: lig = 2: Nx = 5
    .Cells.ClearContents: .[A1] = "CODE ARTICLE"
        For i = 2 To UBound(t, 1)
        data = t(i, 1)
        .Range("A" & lig & ":A" & (lig + Nx)) = data
        lig = lig + Nx + 1
        Next
End With
End Sub
En attendant, la version All Array inclusive 😉
(Mais pour cela, je laisse la place à mes petits camarades de jeux)
 
Bonjour patoq, JM, le forum,
Code:
Sub Extract()
Dim nfois, t, resu(), d As Object, i&, x, j, n&
nfois = 6 'modifiable
t = Sheets("Budget").[A1].CurrentRegion.Columns(9).Offset(1).Resize(, 2) 'tableau, plus rapide, au moins 2 éléments
ReDim resu(1 To nfois * UBound(t), 1 To 1) 'tableau pour le résultat, plus rapide
Set d = CreateObject("Scripting.Dictionary")
For i = 1 To UBound(t) - 1
    x = t(i, 1)
    If x <> "" And Not d.exists(x) Then
        d(x) = ""
        For j = 1 To nfois
            resu(n + j, 1) = x
        Next
        n = n + nfois
    End If
Next
'---restitution---
With Sheets("STJ").[A13] 'à adapter éventuellement
    .Resize(n + 1) = resu
    .Offset(n).Resize(Rows.Count - n - .Row + 1).Delete xlUp 'RAZ en dessous
End With
With Sheets("STJ").UsedRange: End With 'actualise la barre de défilement verticale
End Sub
Bonne journée.
 
Dernière édition:
Notre forum d’entraide est 100 % gratuit et le restera.
Aucune formation payante, aucun fichier à acheter, rien à vendre. Mais comme tout site, nous devons couvrir nos frais pour continuer à vous accompagner.
Soutenez-nous en souscrivant à un compte membre : c’est rapide, vous choisissez simplement votre niveau de soutien et le tour est joué.

Je soutiens la communauté et j’accède à mon compte membre
Retour