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 :

modifier une en-tete word a partir de vba excel


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Décembre 2007
    Messages : 83
    Points : 53
    Points
    53
    Par défaut modifier une en-tete word a partir de vba excel
    bonjour à partir d'une feuille de calcul excel, je veux faire un programme VBA pour transférer les infos dans un rapport ( proposition de vente, facture, bon de livraison..) fait avec WORD.

    Je me suis fait un fichier template qui a le logo de la compagnie, le numéro de page, et de soumission dans l'en-tête. Je sais comment ajouter le nom du client, liste d'item.

    Je cherche a savoir comment modifier seulement le numéro de soumission qui est dans l''en-tête .

    j'ai ce code, mais il remplace tout l'en-tete

    merci de votre aide

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Dim WordApp As Word.Application
    Dim WordDoc As Word.Document
     
        Set WordApp = CreateObject("Word.Application")
        WordApp.Visible = True
        Set WordDoc = WordApp.Documents.Open("r:\temp\PROPOSITION TEMPLATE.doc")
        With WordDoc.Sections(1)
           .Headers(wdHeaderFooterPrimary).Range.Text = "Le titre"
            .Headers(wdHeaderFooterPrimary).Range.Paragraphs.Alignment = wdAlignParagraphCenter
            .Footers(wdHeaderFooterPrimary).PageNumbers.Add
       End With

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    682
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 682
    Points : 723
    Points
    723
    Par défaut
    Bonjour,

    Utilise l'enregistreur de macros propre à Word

    Tu le lances dans ton fichier puis tu vas dans l'entête que tu modifies comme tu veux et tu regardes ce que ça t'a donné niveau code

    En gros,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ActiveWindow.ActivePane.View.SeekView = wdSeekCurrentPageHeader
    pour trouver ton Header. Après tu peux faire ce que tu veux dedans, cela dépend de ton fichier, tu peux te déplacer etc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Selection.MoveRight Unit:=wdCharacter, Count:=20
    Par la suite tu peux effacer, taper du texte...

    Bref, à toi de voir

    EDIT : dans ton fichier, lorsque je lance l'enregistreur de macros pour modifier ta référence en #B0600, j'obtiens ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    ActiveWindow.ActivePane.View.SeekView = wdSeekCurrentPageHeader
        Selection.MoveRight Unit:=wdCharacter, Count:=13
        Selection.Delete Unit:=wdCharacter, Count:=1
        Selection.Delete Unit:=wdCharacter, Count:=1
        Selection.Delete Unit:=wdCharacter, Count:=1
        Selection.Delete Unit:=wdCharacter, Count:=1
        Selection.TypeText Text:="0600"
        ActiveWindow.ActivePane.View.SeekView = wdSeekMainDocument
    Il ne te reste plus qu'à adapter comme tu le souhaites !
    DeaD

  3. #3
    Membre du Club
    Inscrit en
    Mars 2008
    Messages
    81
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 81
    Points : 68
    Points
    68
    Par défaut
    Hello!
    Juste un petit truc qui n'a rien à voir avec du vba, ton fichier à l'air d'être un fichier professionnel.
    Je te signale donc une petite faute d'orthographe:
    "n'inclus", tu as mis un "s" au lieu d'un "t" à la fin.
    Voili voilou

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Décembre 2007
    Messages : 83
    Points : 53
    Points
    53
    Par défaut
    Merci....Dans word, quand j'enrégistre une macro, je ne peux pas aller dans l'entete, mais avec ton code, ca marche sper bien....

    re-merci

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

Discussions similaires

  1. remplire une ComboBox sous Word a partir de c++ Builder
    Par Matsa dans le forum C++Builder
    Réponses: 13
    Dernier message: 25/06/2009, 13h52
  2. Modifier une base de donnee a partir d un userform
    Par cchassan dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 10/02/2008, 17h36
  3. Réponses: 8
    Dernier message: 31/07/2006, 12h52
  4. Cocher une checkbox dans word a partir de vb6
    Par morgan47 dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 11/07/2006, 10h53
  5. Réponses: 3
    Dernier message: 07/06/2006, 21h35

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