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 :

Numérotation ligne code VBA


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    105
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 105
    Par défaut Numérotation ligne code VBA
    Bonjour,

    J'utilise une fonction pour numéroter les lignes de mon code VBA afin de simplifier le suivi des erreurs.

    Une fois numéroté, l'outil de compilation plante sur le 1° CASE dans les SELECT CASE. Pourquoi ?

    cdt, NC

  2. #2
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    probablement parce qu'il y a une erreur sur cette ligne ou sur les conditions préalables au Select Case


    ça ne t'avance pas je présume ce que je viens de dire ? C'est normal, tu ne nous montres même pas ton code, ni décrit l'erreur renvoyée

    A toi de jouer

  3. #3
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut
    Bonjour !

    Citation Envoyé par canard338 Voir le message
    l'outil de compilation plante sur le 1° CASE dans les SELECT CASE. Pourquoi ?
    Cette ligne de code ne respecte pas le langage VBA !

    _________________________________________________________________________________________________________
    Je suis Paris, Istanbul, Berlin, Nice, Bruxelles, Charlie, …

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    105
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 105
    Par défaut
    Bon je la refais plus simplement avec un petit exemple. La compilation ne plante pas pour :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    Sub test()
        I = 2
        Select Case I
            Case 1
                Debug.Print "1"
            Case 2
                Debug.Print "2"
            Case Else
                Debug.Print "Autre"
        End Select
    End Sub
    Je numérote :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    Sub test()
    2    I = 2
    3    Select Case I
    4        Case 1
    5            Debug.Print "1"
    6        Case 2
    7            Debug.Print "2"
    8        Case Else
    9            Debug.Print "Autre"
    10    End Select
    End Sub
    La compilation plante avec le message : Instructions et étiquettes incorrectes entre Select Case et le premier Case
    Je modifie la numérotation et la compilation ne plante plus :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    Sub test()
    2    I = 2
    3    Select Case I
             Case 1
    5            Debug.Print "1"
    6        Case 2
    7            Debug.Print "2"
    8        Case Else
    9            Debug.Print "Autre"
    10    End Select
    End Sub
    Est-ce plus clair ?
    Je trouve ça bizarre.

  5. #5
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut


    Le message d'erreur est pourtant clair et sans compter l'aide associée ‼

    Ce n'est donc pas possible et tout à fait inutile car en cas d'erreur la ligne est déjà surlignée …

  6. #6
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    si tu as numéroté tes lignes, sans laisser de "trous" comme tu nous l'as montré ... et comme Marc-L t'as suggéré que ce n'était pas possible ....


    Erl() te donnera le numéro de ligne

    exemple tout simple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub toto()
    1 Dim t As Integer
    2 On Error GoTo errhandler
    3 t = 20000000
    4 Exit Sub
     
    errhandler:
    MsgBox "Erreur suivante : " & Err.Description & vbCrLf & "A la ligne : " & Erl()
    End Sub


    Après, numéroter ses lignes ou pas ? Un choix perso
    moi je ne l'ai jamais fais (peut-être à tort !)

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

Discussions similaires

  1. [AC-2003] Problème de code vba ligne if surligné en jaune
    Par Piccou dans le forum VBA Access
    Réponses: 26
    Dernier message: 07/08/2009, 09h19
  2. introduire un mot de passe dans la ligne de code VBA
    Par bedoch dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 27/07/2009, 17h56
  3. Bug dans une ligne de code VBA
    Par orlacit dans le forum VBA Access
    Réponses: 5
    Dernier message: 08/11/2007, 15h25
  4. inserer ligne code vba
    Par lindette dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/10/2007, 17h00
  5. ligne incompréhensible code VBA
    Par Anorgasmophobie dans le forum Général VBA
    Réponses: 5
    Dernier message: 01/05/2007, 14h43

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