IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Treeview: Quel est le problème avec mon code!?!? :( [XL-2013]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Homme Profil pro
    Analyse système
    Inscrit en
    Décembre 2019
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Portugal

    Informations professionnelles :
    Activité : Analyse système
    Secteur : Bâtiment

    Informations forums :
    Inscription : Décembre 2019
    Messages : 3
    Par défaut Treeview: Quel est le problème avec mon code!?!? :(
    Salut!

    J'ai du mal à faire fonctionner le code "Change" "Add" et "Remove", mais je n'arrive pas à comprendre ce qui ne va pas ...

    Quelqu'un peut-il aider?
    merci!
    Fichiers attachés Fichiers attachés

  2. #2
    Membre extrêmement actif
    Homme Profil pro
    Inscrit en
    Septembre 2013
    Messages
    1 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2013
    Messages : 1 369
    Par défaut
    Bonjour,

    Remarque: Le niveau dans le tableau n'est pas nécessaire.
    Avec une procédure récursive, le tracé de l'organigramme se fait sans cette colonne.

    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
    Dim tw As MSComctlLib.TreeView
    Dim n, Rng
    Private Sub UserForm_Initialize()
      Set Rng = Range("A2:F" & [F65000].End(xlUp).Row)
      pere = Rng(1, 1)
      nomPere = Application.VLookup(pere, Rng, 4, False)
      Set tw = Nothing
      Set tw = Me.MonArbre
      n = Rng.Rows.Count
      tw.Nodes.Add(, , "NoeudMat" & pere, nomPere).Expanded = True    ' Racine arbre
      Fils pere
    End Sub
     
    Sub Fils(parent)       ' procédure récursive
      For i = 2 To n
        cd = Rng(i, 1)
        niv = Len(cd) - Len(Replace(cd, ".", ""))
        If niv = 0 Then temp = "0" Else temp = Left(cd, Len(cd) - 2)
        If temp = parent Then
          tw.Nodes.Add("NoeudMat" & parent, tvwChild, "NoeudMat" & _
            Rng(i, 1), Rng(i, 1) & ": " & Rng(i, 2) & "-" & Rng(i, 4)).Expanded = True
          Fils Rng(i, 1)
        End If
      Next i
    End Sub
    Nom : Sans titre.png
Affichages : 425
Taille : 48,1 Ko

    Boisgontier

  3. #3
    Membre extrêmement actif
    Homme Profil pro
    Inscrit en
    Septembre 2013
    Messages
    1 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2013
    Messages : 1 369
    Par défaut
    J'ai repris votre BD avec mon code en ne gardant que les colonnes utiles.

    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
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    Dim tw As MSComctlLib.TreeView
    Dim n, Rng
    Private Sub UserForm_Initialize()
      Set Rng = Range("A2:C" & [A65000].End(xlUp).Row)
      pere = "0"
      nomPere = Application.VLookup(pere, Rng, 2, False)
      Set tw = Me.MonArbre
      n = Rng.Rows.Count
      tw.Nodes.Add(, , "NoeudMat" & pere, nomPere).Expanded = True    ' Racine arbre
      Fils pere
    End Sub
     
    Sub Fils(parent)       ' procédure récursive
      For i = 2 To n
        cd = Rng(i, 1)
        niv = Len(cd) - Len(Replace(cd, ".", ""))
        If niv = 0 Then temp = "0" Else temp = Left(cd, Len(cd) - 2)
        If temp = parent Then
          tw.Nodes.Add("NoeudMat" & parent, tvwChild, "NoeudMat" & _
            Rng(i, 1), Rng(i, 1) & ": " & Rng(i, 2) & "-").Expanded = True
          Fils Rng(i, 1)
        End If
      Next i
    End Sub
     
    Private Sub MonArbre_NodeClick(ByVal Node As MSComctlLib.Node)
      If Left(Node.Key, 8) = "NoeudMat" Then
        Me.code = Application.VLookup(Mid(Node.Key, 9), Rng, 1, False)
        Me.Description = Application.VLookup(Mid(Node.Key, 9), Rng, 2, False)
        Me.Valeur = Application.VLookup(Mid(Node.Key, 9), Rng, 3, False)
      End If
    End Sub
     
    Private Sub B_modif_Click()
      Set result = Rng.Find(what:=Me.code)
      If Not result Is Nothing Then
        ligne = result.Row - 1
        Rng(ligne, 2) = Me.Description
        Rng(ligne, 3) = CDbl(Me.Valeur)
      End If
    End Sub
     
    Private Sub b_sup_Click()
      Set result = Rng.Find(what:=Me.code)
      If Not result Is Nothing Then
        ligne = result.Row - 1
        If MsgBox("Etes vous sûr de supprimer " & Me.code & "?", vbYesNo) = vbYes Then
          Rng.Rows(ligne).Delete
          tw.Nodes.Clear
          UserForm_Initialize
        End If
      End If
    End Sub
     
    Private Sub B_ajout_Click()
      Set f = Sheets("bd")
      ligne = f.[A65000].End(xlUp).Row + 1
      f.Cells(ligne, 1) = Me.code
      f.Cells(ligne, 2) = Me.Description
      f.Cells(ligne, 3) = CDbl(Me.Valeur)
      tw.Nodes.Clear
      UserForm_Initialize
    End Sub
    Nom : Sans titre.png
Affichages : 537
Taille : 115,3 Ko

    Boisgontier

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Problème avec mon code - un aperçu
    Par nsimon70 dans le forum Flash
    Réponses: 1
    Dernier message: 14/02/2008, 12h47
  2. [MySQL] problème avec mon code (envoi données) ?
    Par cuisto44000 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 20/12/2007, 09h45
  3. probléme avec mon code JAVA et MYSQL
    Par ulysse031 dans le forum JDBC
    Réponses: 5
    Dernier message: 10/05/2007, 00h46
  4. [MySQL] OU est le probléme avec ce code ??
    Par adlich dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 27/04/2006, 17h47
  5. Quel est le problème dans ce code ?
    Par Luther13 dans le forum C
    Réponses: 12
    Dernier message: 26/08/2003, 16h09

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo