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 :

[VBA][Word]Sauvegarder sans les macros


Sujet :

VBA Word

  1. #1
    Membre habitué Avatar de Oui-Oui MB
    Homme Profil pro
    Architecte technique
    Inscrit en
    Avril 2005
    Messages
    111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Belgique

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Avril 2005
    Messages : 111
    Points : 127
    Points
    127
    Par défaut [VBA][Word]Sauvegarder sans les macros
    Bonjour !

    J'aimerais pouvoir faire cette chose qui parait si simple : sauvegarder mon fichier (sous un autre nom) mais sans les macros.

    Le contexte est simple : j'ai un fichier avec des tags spéciaux dedans et un fichier de donnée. Lors de l'ouverture, une macro lit le fichier de donnée et remplis les tags et après doit sauver le fichier (avec un autre nom). Ce dernier ne doit pas contenir de macro...

    Est-ce possible ?
    Que la Schtuche soit avec vous !!!

  2. #2
    Membre habitué Avatar de Oui-Oui MB
    Homme Profil pro
    Architecte technique
    Inscrit en
    Avril 2005
    Messages
    111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Belgique

    Informations professionnelles :
    Activité : Architecte technique

    Informations forums :
    Inscription : Avril 2005
    Messages : 111
    Points : 127
    Points
    127
    Par défaut
    Voila j'ai bien chipoté et j'ai trouvé une jolie bidouille pour parvenir à mes fins...

    Le truc consiste à sauver le document au format rtf (comme ça, il ne contient plus de macros) puis de le remettre au format doc.

    Voici mon bout de code :
    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
     
    Sub SaveWithoutMacro()
     
        'Enregistre le document sans les macros
     
        'Methode de fou :
        ' - enregistrer le document
        ' - en créer une copie qu'on ouvre (A)
        ' - enregistrer A en tant que rtf (-> enleve les macros)
        ' - re-enregistrer A en tant que doc
     
        Dim path, filename, nfname As String
        Dim docCur, docNew As Document
     
        'Sauvegarde
        ThisDocument.Save
     
        path = ThisDocument.path
        filename = ThisDocument.Name
     
        'Creation d'une copie
        CopyFile path & "\" & filename, path & "\_tmp_" & filename, False
     
        'Ouverture de cette copie
        Set docCur = ThisDocument
        Set docNew = Documents.Open(path & "\_tmp_" & filename)
     
        'Enregistrer docNew en rtf
        docNew.SaveAs filename:=path & "\_tmp_" & filename & ".rtf", FileFormat:=wdFormatRTF
     
        'Fermer ce fichier
        docNew.Close
     
        'Re ouvrir docNew
        Set docNew = Documents.Open(path & "\_tmp_" & filename & ".rtf")
     
        'Sauvegarde en doc
        nfname = Strings.Mid(filename, 2)
        docNew.SaveAs filename:=path & "\" & nfname, FileFormat:=wdFormatDocument
     
        'Kill des 2 fichiers temporaires
        Kill path & "\_tmp_" & filename & ".rtf"
        Kill path & "\_tmp_" & filename
     
        'Fermeture du template
        ThisDocument.Saved = True
        Application.ActiveDocument.Saved = True
        docCur.Close
     
    End Sub
    Que la Schtuche soit avec vous !!!

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3
    Points : 3
    Points
    3
    Par défaut Et s'il y a des images ?
    ton document doit forcément n'être que du texte, tout ce qui est tableaux, images dégage, non ?

  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
    Le RTF peut contenir des objets sans aucune difficulté.

    Tout est gardé, les images, les tableaux et les objets OLE.
    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 !

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

Discussions similaires

  1. [VBA Word] Next sans for
    Par Dobyan08 dans le forum VBA Word
    Réponses: 6
    Dernier message: 20/10/2016, 10h57
  2. [PPT-2007] Sauvegarder une presentation sans les macros
    Par Akxn0008 dans le forum VBA PowerPoint
    Réponses: 1
    Dernier message: 08/07/2009, 18h06
  3. Réponses: 5
    Dernier message: 27/08/2008, 11h03
  4. Enregistrer Un Classeur Sans Les Macros
    Par potters dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 20/06/2007, 08h48
  5. VBA Word - Aide sur les "Retours" dans tableaux
    Par wouebmaster dans le forum VBA Word
    Réponses: 5
    Dernier message: 29/12/2005, 10h08

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