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 :

Formater export Excel vers Word via signet [WD-2003]


Sujet :

VBA Word

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Directeur Qualité
    Inscrit en
    Janvier 2010
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Directeur Qualité

    Informations forums :
    Inscription : Janvier 2010
    Messages : 39
    Points : 35
    Points
    35
    Par défaut Formater export Excel vers Word via signet
    Bonjour,

    J'ai une macro Excel qui ouvre un document Word et qui envoie des valeurs de différentes cellules aux emplacements définis par des Signets.

    Je voudrais choisir ensuite la couleur du texte que j'ai placé dans mon document.

    Exemple :
    Si c'est un 8 en rouge et si c'est un 14 en vert.

    Si je sélectionne le signet, seul l'emplacement du signet est sélectionné et pas le texte que j'ai inséré.

    Comment faire s'il vous plait ? Je n'ai rien trouvé sur le sujet dans ce forum ou sur le net en général.

    Merci à vous pour votre aide.

  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,

    Aurais-tu le code qui injecte le texte dans les signets, possible qu'il faille le faire lors de l'injection.
    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
    Nouveau membre du Club
    Homme Profil pro
    Directeur Qualité
    Inscrit en
    Janvier 2010
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Directeur Qualité

    Informations forums :
    Inscription : Janvier 2010
    Messages : 39
    Points : 35
    Points
    35
    Par défaut Code pour les signets
    http://vb.developpez.com/faqvba/?pag...portdataSignet

    On n'est jamais mieux servi que par Developpez.com !!!

  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,

    Si tes signets sont des points d'insertions et de ce fait ne contiennent pas de données et si ce n'est pas le cas, le signet est effacé.

    Changer la couleur du texte ne sera pas possible après avoir mis le texte.

    Tu dois faire un test sur le contenu avant d'insérer les données et passer par une sélection pour mettre la couleur que tu veux en fonction du texte.
    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
    Nouveau membre du Club
    Homme Profil pro
    Directeur Qualité
    Inscrit en
    Janvier 2010
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Directeur Qualité

    Informations forums :
    Inscription : Janvier 2010
    Messages : 39
    Points : 35
    Points
    35
    Par défaut Précision
    Merci Olivier pour ta réponse. Peux-tu détailler "passer en sélection".

    J'ai essayé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
        With WordDoc.Bookmarks("Nom_Signetl")
           .Range.Font.Color = wdColorRed
           .Range.Font.Bold = True
           .Range.Text = "8"
        End With

    Mais j'obtiens le même résultat

  6. #6
    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,

    Dans ton code, tu modifies le contenu du signet qui ne contient rien.

    Pour que ça fonctionne, il faut que le signet contienne au moins un caractère qui peut être un espace.

    Dans ce cas, ce code fonctionne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    ActiveDocument.Bookmarks("s1").Range.Select
     
    Selection.Range.Font.ColorIndex = wdBlue
    Selection.TypeText "Olivier"
    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 !

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Directeur Qualité
    Inscrit en
    Janvier 2010
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Directeur Qualité

    Informations forums :
    Inscription : Janvier 2010
    Messages : 39
    Points : 35
    Points
    35
    Par défaut Formatage du signet en couleur
    Merci pour m'avoir orienté. Faute d'y arriver avec ActiveDocument, je me suis inspiré de ta proposition et j'obtiens cela qui fonctionne bien :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Set myRange = WordDoc.Range(Start:=WordDoc.Bookmarks("Signet1").Start, End:=WordDoc.Bookmarks("Signet1").Start + 1)
        With myRange
            .Select
            .Font.Color = wdRed
            .Bold = True
            .Text = "blabla"
        End With
    Encore merci.
    Au fait Olivier : tu es beau....

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

Discussions similaires

  1. D'Excel vers Word via VBA
    Par Juunii dans le forum VBA Project
    Réponses: 17
    Dernier message: 25/05/2015, 20h47
  2. [XL-2007] transfert données excel vers word via plusieurs macro!
    Par yannick63430 dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 18/12/2010, 21h41
  3. [Toutes versions] export excel vers word erreur 6028
    Par galzinc dans le forum Excel
    Réponses: 2
    Dernier message: 14/08/2009, 12h58
  4. export tableau excel vers word
    Par camzo dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 03/10/2007, 18h53
  5. [VBA-Word] Exportation Excel vers Word
    Par le_sonic dans le forum VBA Word
    Réponses: 6
    Dernier message: 20/12/2006, 17h18

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