Bonjour,
Malgré le peu de connaissance que j'ai en VBA votre forum m'a ete d'une grand aide avec tous ces exemples et explications.
J'ai réussi a affiché dynamiquement des données mais je pense qu'il serais possible d’amélioré les syntaxes vu que je ne suis pas un pro
si vous pouvez y jeté un œil et me dire ce qu'il ne va pas

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
Sub Ajout()
        j = Application.CountA(Sheets("BD").Range("L:L"))
        ligne = 13
        l = (j + 13) - 2 'L sera la longueur du tableau j + 13 lignes (debut du tableau)
 
        For i = 2 To j 'i est debut colonne des dates
        colonne = 1
        'copie ligne Nom_BD vers planning
        Sheets("Planning").Range("A" & ligne).FormulaLocal = "=BD!" & Cells(i, 12).Address(True, True)
        'Sheets("Planning").Range("A" & ligne).Borders.Value = 1
        colonne = colonne + 1
        'burdure pour la liste de nom_bd
        Sheets("Planning").Cells(ligne, 1).Borders.Value = 1
 
            While colonne < 33 '33 derniere colonne jours
                If colonne <= 26 Then 'transformation colonne chiffre en charactere type A, B ... AA, AB
                x = Chr(64 + colonne)
                Else
                x = "A" + Chr(64 + (colonne - 26)) 'table de charactere ascii (chr)
                End If
                'ajout d'une formule avec des variables a chaque cellules du tableau
                Sheets("Planning").Cells(ligne, colonne).FormulaLocal = "=SI(SOMMEPROD((Noms=$A" & ligne & ")*(" & x & "$12>=Début)*(" & x & "$12<=Fin))>0;INDEX(Taches;SOMMEPROD((Noms=$A" & ligne & ")*(" & x & "$12>=Début)*(" & x & "$12<=Fin)*LIGNE(Noms))-1);"""")"
                Sheets("Planning").Cells(ligne, colonne).Borders.Value = 1
 
                    'si un nom de la liste sur la feuille BD a ete suprimer le tableau reactualise tout
                    'et supprime grace a la derniere valeur de L le contenue et la bordure
                    If Sheets("Planning").Range("A" & l + 1) = "" Then
                    Sheets("Planning").Cells(l + 1, colonne).FormulaLocal = ""
                    Sheets("Planning").Cells(l + 1, 1).Borders.Value = 0
                    Sheets("Planning").Cells(l + 1, colonne).Borders.Value = 0
                    End If
                colonne = colonne + 1
 
             Wend
 
        ligne = ligne + 1
 
        Sheets("Planning").Range("A" & l + 1).FormulaLocal = ""
 
        Next i
 
 
      End Sub