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 :

Mots réservés VB


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2013
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Distribution

    Informations forums :
    Inscription : Mars 2013
    Messages : 27
    Par défaut Mots réservés VB
    Bonjour

    J'ai un problème assez pointu, j'analyse un code vba mot par mot, et je voudrais que mon programme me sépare les mots réservés (dim, integer, string, as) du reste (noms des variables, chiffres, signes)

    Connaissez-vous un moyen d'accéder au dictionnaire des mots réservés par VB.

    Merci d'avance.

  2. #2
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Il y a Notepad++, c'est gratuit (je ne fais pas de publicité)

  3. #3
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2013
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Distribution

    Informations forums :
    Inscription : Mars 2013
    Messages : 27
    Par défaut
    Merci, mais en fait je cherche une commande vba qui en gros quand on lui passe en argument dim, as, integer, for ou autre mot du genre nous indique que c'est un mot réservé et quand on lui passe stChaine, wbClasseur, i indique que ce n'est pas un mot reservé.

    Merci d'avance.

  4. #4
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    1 733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 1 733
    Par défaut
    Tu mets option explicit en haut de ton code... Ca va t'obliger à tout dimensionner... Une fois ceci fait, toutes tes variables déclarées seront des mots non réservés.

  5. #5
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Est ce que tu peux faire ceci? Je veux nommer ma variable For

  6. #6
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    1 733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 1 733
    Par défaut
    Non, pourquoi cette question ?

  7. #7
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    @EngueEngue

    La question était destinée à Libesa. Ton intervention s'est placée entre temps.

    Bon voilà tu as répondu car je n'appréhende pas le problème de Libesa

  8. #8
    Membre extrêmement actif
    Avatar de NVCfrm
    Homme Profil pro
    Administrateur Système/Réseaux - Developpeur - Consultant
    Inscrit en
    Décembre 2012
    Messages
    1 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Administrateur Système/Réseaux - Developpeur - Consultant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 037
    Billets dans le blog
    5
    Par défaut
    Citation Envoyé par Libesa Voir le message
    Bonjour

    J'ai un problème assez pointu, j'analyse un code vba mot par mot, et je voudrais que mon programme me sépare les mots réservés (dim, integer, string, as) du reste (noms des variables, chiffres, signes)

    Connaissez-vous un moyen d'accéder au dictionnaire des mots réservés par VB.

    Merci d'avance.
    La liste des mots clés est disponible dans l'aide intégrée.

    Si je comprends bien, tu voudrais examiner une source à travers un programme.
    Merci, mais en fait je cherche une commande vba qui en gros quand on lui passe en argument dim, as, integer, for ou autre mot du genre nous indique que c'est un mot réservé et quand on lui passe stChaine, wbClasseur, i indique que ce n'est pas un mot reservé.
    Non cette commande n'existe pas! Il te faut la programmer toi même.

  9. #9
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    1 733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 1 733
    Par défaut
    Ce que j'ai compris c'est qu'elle veut lister toutes les variables d'une routine; c'est pourquoi avec un option explicit elle se verra obligée de toute les déclarer et elle en aura la liste.

  10. #10
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2013
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Distribution

    Informations forums :
    Inscription : Mars 2013
    Messages : 27
    Par défaut
    Bonjour

    Non je veux pas du tout lister les variables.
    Voici ce que je veux faire, avec un exemple minimaliste comme celui ci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Dim stNombre as String
    Dim intNombre as Integer
     
    intNombre=Cint(stNombre)
    Mon code possede 11 mots, je souhaite recup dans un tableau les valeurs: Dim, as, String, Dim, as, Integer, Cint; et dans un deuxième tableau stNombre, intNombre, intNombre, stNombre.

    Merci pour vos idées.

  11. #11
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    1 733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 1 733
    Par défaut
    La fonction n'existe pas...

    Tu peux te galérer à coder un truc dans le genre:

    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
    Sub toto()
    Dim Tablo1(1 To 10)
    Dim k As Integer
    k = 1
    reservvba = Array("AddHandler", "AddressOf", "Alias", "And", "Dim", "As", "String", "Integer", "CInt") '... Rajoute tous les autres
    signes = Array("+", "-", "*", "=", "/")
    Text = "Dim stNombre As String Dim intNombre As Integer intNombre = CInt(stNombre)"
    Test = Split(Text, " ")
    For i = LBound(Test) To UBound(Test)
    For j = LBound(reservvba) To UBound(reservvba)
    If Test(i) = reservvba(j) Then
    Tablo1(k) = Test(i)
    Debug.Print Tablo1(k)
    k = k + 1
    End If
    Next j
    Next i
    End Sub
    Ici la liste des mots clés:
    http://msdn.microsoft.com/en-us/libr...(v=vs.90).aspx

    Une fois ton code terminé poste le nous il sera intéressant de voir ta façon de gérer les "(" et les "." !

  12. #12
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2013
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Distribution

    Informations forums :
    Inscription : Mars 2013
    Messages : 27
    Par défaut
    Merci.

    C'est la conclusion à laquelle j'étais arrivé il faut géré ca avec une liste exhaustive des mots reservés.

    Pour les parenthèses et point, c'est facile aucun mot reservé ni aucune de mes variables ne fait moins de 2 lettres, donc avec une condition sur len<2, ca devrait le faire.

    Mais effectivement en utilisant split (test, " ") je vais être embété par des expressions du genre ThisWorkbook.VBProject.VBComponents("TEST").

    Faut que je reflechisse à tout ça.

Discussions similaires

  1. java, mots réservés.
    Par Empty_body dans le forum JDBC
    Réponses: 3
    Dernier message: 15/12/2006, 16h39
  2. [ANTLR]gérer des mots réservés
    Par anitshka dans le forum EDI et Outils pour Java
    Réponses: 9
    Dernier message: 18/08/2006, 16h29
  3. Question sur l'utilisation du mot réservé static
    Par flash2590 dans le forum Langage
    Réponses: 4
    Dernier message: 10/04/2006, 00h20
  4. [MySQL] mot réservé dans un nom de champ
    Par dreamwanderer dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 10/12/2005, 20h54
  5. Year (mot réservé)
    Par Fir dans le forum Langage SQL
    Réponses: 10
    Dernier message: 21/02/2003, 12h16

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