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 :

Code erreur 9 - Set tbl = ws.ListObjects


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    470
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2009
    Messages : 470
    Par défaut Code erreur 9 - Set tbl = ws.ListObjects
    Bonjour à tous,


    Le code suivant me retourne un code erreur 9 subsrcipt out of range. Pourtant l(orthographe de la table et du sheet1 sont bons.
    IL stoppe sur Bibi.

    Quelqu'un sait de quoi il retourne ?

    Merci d'avance

    Habiler


    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
    Sub PopupAvecDonnéesTable()
     
        ' Define variables
        Dim ws As Worksheet
        Dim tbl As ListObject
        Dim tblRange As Range
        Dim popupText As String
     
        ' Définition table et variables
        Set ws = ActiveWorkbook.Worksheets("Sheet1") 'Emplacement de la table
        Set tbl = ws.ListObjects("Bibi") ' Nom de la table
     
        ' Set de la table range variable
        Set tblRange = tbl.Range
     
        ' Parcourt les rangées et colonnes et construit le popup
        For i = 1 To tblRange.Rows.Count
            For j = 1 To tblRange.Columns.Count
                popupText = popupText & tblRange.Cells(i, j).Value & vbTab
            Next j
            popupText = popupText & vbCrLf
        Next i
     
        ' Affichage du popup avec les données de la table
        MsgBox prompt:=popupText, Title:="Données de ...."
     
    End Sub

  2. #2
    Membre émérite
    Homme Profil pro
    Retraité
    Inscrit en
    Octobre 2022
    Messages
    685
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Octobre 2022
    Messages : 685
    Par défaut
    Bonjour,

    Chez moi ceci fonctionne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub test()
        Dim ws As Worksheet
        Dim tbl As ListObject
        Set ws = ActiveWorkbook.Worksheets("Feuil2") 'Emplacement de la table
        Set tbl = ws.ListObjects("Bibi") ' Nom de la table
        Debug.Print tbl.Name
    End Sub
    Tu es sûr que Activeworkbook est bien le classeur que tu imagines ?

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    470
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2009
    Messages : 470
    Par défaut
    J' essayé avec un fichier test sheet1 sheet2 et même book1 sans résutltats

    Book1.xlsm

  4. #4
    Membre émérite
    Homme Profil pro
    Retraité
    Inscrit en
    Octobre 2022
    Messages
    685
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Octobre 2022
    Messages : 685
    Par défaut
    Bonjour,

    ton tableau s'appelle Table1. C'est la colonne qui s'appelle Bibi.

    Nom : _Capture d’écran 2023-03-15 133943.png
Affichages : 172
Taille : 26,5 Ko

    Pour modifier le nom du tableau, cliquer dedans et sélectionner "Création de tableau" dans le ruban, à droite.

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    470
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2009
    Messages : 470
    Par défaut
    Re,

    Ok cela marche en test mais en réel j'ai à nouveau le même problème.

    J'ai en feuille "BaremesIndexed" la tabke Ech_24k et en feuille fonctions différents calculs.
    J'ai donc le code suivant qui me renvoie Subscript out of range soit avec ou sanc code error 9.Nom : 24k.png
Affichages : 171
Taille : 25,1 KoNom : 24k2.png
Affichages : 150
Taille : 7,2 Ko


    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
    Sub PopupAvecDonnéesTable()
     
        ' Define variables
        Dim ws As Worksheet
        Dim tbl As ListObject
        Dim tblRange As Range
        Dim popupText As String
     
        ' Définition table et variables
        Set ws = ActiveWorkbook.Worksheets("BaremesIndexed") 'Emplacement de la table
        Set tbl = ws.ListObjects("Ech_24k") ' Nom de la table
     
        ' Set de la table range variable
        Set tblRange = tbl.Range
     
        ' Parcourt les rangées et colonnes et construit le popup
        For i = 1 To tblRange.Rows.Count
            For j = 1 To tblRange.Columns.Count
                popupText = popupText & tblRange.Cells(i, j).Value & vbTab
            Next j
            popupText = popupText & vbCrLf
        Next i
     
        ' Affichage du popup avec les données de la table
        MsgBox prompt:=popupText, Title:="Données de ...."
     
    End Sub

  6. #6
    Membre émérite
    Homme Profil pro
    Retraité
    Inscrit en
    Octobre 2022
    Messages
    685
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Octobre 2022
    Messages : 685
    Par défaut
    Re.

    Tu ne dis pas quelle est la ligne qui plante. Le set ws ou le set tbl ou autre ?

    Tu n'a pas répondu à "Tu es sûr que Activeworkbook est bien le classeur que tu imagines ?"

    Sinon tu as essayé de mettre un debug pour tracer ws.ListObjects.count ou ws.ListObjects(1).name ?

  7. #7
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 182
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 182
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    La dernière image publiée ne semble pas être un tableau structuré.
    Vous avez peur de quoi avec ces images partielles où l'on ne visualise pas le minimum pour vous aider

    Je partage le questionnement de "Tête de chat", si c'est vraiment un tableau structuré, le classeur où il se trouve ne doit pas être le classeur actif
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  8. #8
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    470
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2009
    Messages : 470
    Par défaut
    Bonsoir à tous,

    Ce n'était effectivement pas une table structurée.

    Un SUPER merci

    Habiler

Discussions similaires

  1. [Mail] récupérer les code erreurs de mail()
    Par Djakisback dans le forum Langage
    Réponses: 2
    Dernier message: 22/03/2006, 18h19
  2. [TSQLStoredProc] Comment connaitre le code erreur renvoye ?
    Par kase74 dans le forum Bases de données
    Réponses: 4
    Dernier message: 24/08/2005, 12h08
  3. Code erreur 131
    Par taket dans le forum SQL Procédural
    Réponses: 6
    Dernier message: 29/06/2005, 16h43
  4. Codes erreur spécifiques
    Par jibe74 dans le forum Débuter
    Réponses: 3
    Dernier message: 10/12/2004, 12h19
  5. [Kylix] code erreur :-10 :(
    Par maamar dans le forum EDI
    Réponses: 2
    Dernier message: 21/09/2003, 02h15

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