Créer un plan - excel vba
Résoluyg_be Messages postés 23541 Date d'inscription Statut Contributeur Dernière intervention -
Bonjour,
J'ai un fichier Excel avec plus de 60000 lignes représentant des nomenclatures d'ensembles. Dans ce fichier, j'ai mis dans la première colonne les niveaux de nomenclature.
Je souhaite grouper les lignes en créant un plan. Comme en exemple sur le fichier joint dans l'onglet "avec plan". Avec 60000 lignes, ça va être fastidieux de le faire manuellement. Donc je souhaiterai le faire avec une macro.
Mais je bloque. J'ai essayé de faire des boucles en testant la valeur de la cellule dans la colonne "Niveau", mais je me perds dans les boucles et le passage d'une ligne à l'autre.
Enfin bref, est-ce que quelqu'un aurait une idée svp ?
Merci d'avoir lu ma question :)
(Je suis en Excel 2016)
- Créer un plan - excel vba
- Créer un compte google - Guide
- Comment créer un groupe whatsapp - Guide
- Créer liste déroulante excel - Guide
- Créer un lien pour partager des photos - Guide
- Créer un compte gmail - Guide
2 réponses
bonjour, suggestion:
Option Explicit Sub plan() Dim fl As Worksheet, niveau As Integer, premcel As Range, cel As Range Debug.Print Now() Set fl = Sheets("sans plan") For niveau = 1 To 4 Set cel = fl.[a2] Do While cel <> "" If cel > niveau Then Set premcel = cel Do Set cel = cel.Offset(1) Loop Until cel <= niveau Or cel = "" Debug.Print niveau, premcel.Row, cel.Row - 1 Range(premcel, cel.Offset(-1)).Rows.Group Else Set cel = cel.Offset(1) End If Loop Next niveau End Sub
Ci-dessous le lien de mon fichier
https://www.cjoint.com/c/NIfvFdnLE3F
Bonjour,
Je n'ai pas mis le code, car j'ai bloqué dessus.
J'ai fait l'enregistreur pour voir le code pour grouper, mais c'est tout le passage de test que je n'arrive pas à faire.
Ci-dessous mon essai de début de code : (les dernières lignes sont en commentaires, elles proviennent d'un enregistrement que j'ai fait sur un autre fichier, pour voir le code pour grouper)
Sub Plan()
'
' Plan Macro
'
'
Range(A2).Select
Selection.End(xlDown).Select
ActiveCell.Select
derlignetotal = ActiveCell.Row
Range(A2).Select
premlignetotal = ActiveCell.Row
For i = premlignetotal To derlignetotal
premligne = premlignetotal
pligne = 0
For j = premligne To derlignetotal
If Range("A" & j).Value < 4 Then
Range("A" & j + 1).Select
ElseIf Range("A" & j).Value = 4 And pligne = 0 Then
pligne = j
Range("A" & j + 1).Select
ElseIf Range("A" & j).Value = 4 And pligne > 0 Then
Range("A" & j + 1).Select
Else: Rows("premligne:j").Select
Selection.Rows.Group
End If
j = j + 1
Next
' Rows("17:21").Select
' Selection.Rows.Group
' Rows("23:23").Select
' Rows("23:62").Select
' Selection.Rows.Group
' Rows("16:16").Select
' Rows("16:149").Select
' Selection.Rows.Group
End Sub
J'ai voulu faire une première boucle pour balayer tout le fichier, car je pensais faire ensuite d'autres boucles pour les niveaux 1, 2, 3 et 4. Mais déjà dans la boucle pour le niveau 4, je m'y perds pour savoir comment passer à la ligne suivante et ensuite sélectionner toutes les lignes que je veux grouper.
Je ne sais pas si je sui très claire dans mes explications. Désolée.
La différence principale par rapport à ton code, c'est l'utilisation de boucles do au lieu de boucles for.
Je travaille avec des cellules plutôt qu'avec des numéros de lignes, mais c'est un détail, je le fais par facilité.
Merci beaucoup !! :)
ça fonctionne nickel.
Il faut vraiment que je regarde la fonction Do While...Loop, car je ne la connais pas trop et donc je n'y pense pas du tout.
J'ai juste une petite question ; Pourquoi vous mettez Debug.print ? ça sert à quoi exactement ?
En tout cas, merci.
Bonne journée
le debug.print affiche de l'information dans la fénêtre d'exécution (ctl-G dans l'éditeur de code). cela permet de comprendre ce que fait le code.