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

VBA Word Discussion :

Afficher résultat d'une fonction VBA dans un champ Word


Sujet :

VBA Word

  1. #1
    Membre expérimenté
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    747
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 747
    Points : 1 332
    Points
    1 332
    Par défaut Afficher résultat d'une fonction VBA dans un champ Word
    Bonjour à tous,

    J'ai créé une fonction en VBA (Function sur Excel initialement et elle fonctionne, elle n'utilise aucune spécificité du VBA Excel et donc devrait fonctionner sur Word)
    En Excel, facile, on appelle directement la fonction dans la feuille de calcul
    Et en Word ? J'ai essayé des champs de plusieurs types, des champs de formulaires... sans succès
    y a t-il une recette miracle ou dois-je faire une macro qui remplit un signet avec le résultat de ma fonction (ou toute autre astuce alambiquée qui ne me serait pas venue à l'esprit...)

    Merci de m'avoir lu

  2. #2
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Salut,

    Tu peux l'utiliser partout.
    Pour remplir un champ de formulaire, un signet, une cellule de tableau, directement dans le texte.

    Si tu pouvais nous dire comme tu fais, on pourrait peut-être mieux te guider.
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  3. #3
    Membre expérimenté
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    747
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 747
    Points : 1 332
    Points
    1 332
    Par défaut
    Salut ,

    Merci de ta réponse
    prenons une fonction simple, la fonction en elle-même n'a pas d'impact je pense

    Dans un module du document : (est-ce le bon endroit ?)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Function tiptop(a As Double) As Double
    tiptop = a * 2
    End Function
    Si je fais un tableau avec des nombres
    Onglet Insertion - Quickpart - Champ
    Formule
    =tiptop(A1)
    => Erreur de syntaxe

    Même problème avec des champs de formulaire (ancienne version) et un champ Texte de type Calcul avec la même formule

    Qu'ai-je loupé ?

  4. #4
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Salut,

    Contrairement à Excel, les fonctions ne sont pas directement utilisables en Word.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub Document_Open()
    ActiveDocument.FormFields(1).Result = tiptop(1,45)
    End Sub
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  5. #5
    Membre expérimenté
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    747
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 747
    Points : 1 332
    Points
    1 332
    Par défaut
    Bonjour à tous,

    Merci de ta réponse, j'aurais aimé que ce soit plus simple^^

    Bon, je me suis débrouillé en écrivant le résultat dans un signet

    Je joins mon exemple si ça peut intéresser quelqu'un
    Fichiers attachés Fichiers attachés

Discussions similaires

  1. Réponses: 2
    Dernier message: 04/02/2011, 15h11
  2. Réponses: 3
    Dernier message: 22/09/2010, 22h00
  3. [XL-2003] Utiliser une fonction VBA dans une cellule
    Par zakuli dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 20/08/2009, 19h23
  4. Intégrer une fonction VBA dans une requête
    Par chelmi95 dans le forum IHM
    Réponses: 1
    Dernier message: 15/09/2008, 18h55
  5. Réponses: 6
    Dernier message: 02/10/2006, 12h13

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