Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Word > VBA Word
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 02/07/2007, 12h38   #1
Membre régulier
 
Inscription : janvier 2003
Messages : 376
Détails du profil
Informations forums :
Inscription : janvier 2003
Messages : 376
Points : 76
Points : 76
Par défaut enregistrer sous avec nom automatique

Re bonjour,

J'obtiens un fichier word via un publipostage

Je voudrais créer une macro permettant d'enregistrer le fichier issu du publipostage avec un nom préformaté c'est à dire en reprenant la valeur d'un champ de fusion.

En gros le publipostage se fait selon 2 champs (Nom & Lot) du coup lorsque je fusionne tout j'obtiens un fichier word que je voudrais enregistrer avec nom_lot.doc

Est ce possible?

Merci de votre aide

Nini
liop49 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/07/2007, 15h27   #2
Nouveau Membre du Club
 
Inscription : février 2006
Messages : 197
Détails du profil
Informations forums :
Inscription : février 2006
Messages : 197
Points : 31
Points : 31
Ca m'interesse également...
gregb34 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/07/2007, 16h59   #3
Membre régulier
 
Inscription : janvier 2003
Messages : 376
Détails du profil
Informations forums :
Inscription : janvier 2003
Messages : 376
Points : 76
Points : 76
J'ai réussi en bidouillant pas mal mais ça marche

Voici le code :
Code :
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
Private Sub Document_Open()
 
' Macro enregistrée le 02/07/2007 par Nicolas BAUDRY
'
 
'cela permet de faire la fusion du publipostage en automatique dès l'ouverture du fichier word relié à la base de données
    With ActiveDocument.MailMerge
        .Destination = wdSendToNewDocument
        .SuppressBlankLines = True
        With .DataSource
            .FirstRecord = ActiveDocument.MailMerge.DataSource.ActiveRecord
            .LastRecord = ActiveDocument.MailMerge.DataSource.ActiveRecord
        End With
        .Execute Pause:=False
    End With
 
nomfich = Word.ActiveDocument.Name
 
 
' Message pour l'utilisateur    
Msg = "Voulez-vous enregistrer le CB " & vbCrLf & "Cliquez sur 'Oui' pour enregistrer"    ' Définit le message.
        Style = vbYesNo + vbQuestion    ' Définit les boutons.
        Title = "Demande d'enregistrement"    ' Définit le titre.
 
        Response = MsgBox(Msg, Style, Title) ' Affiche le message.
 
        If Response = vbYes Then    ' L'utilisateur a choisi Oui.
 
'Je recherche le champ "lot" se trouvant juste derrière les caractères "Lot N° "
With Selection.Find
    .Forward = True
    .ClearFormatting
    .MatchWholeWord = True
    .MatchCase = False
    .Wrap = wdFindContinue
    .Execute FindText:="Lot n° "
End With
 
' Je sélectionne le champ "lot"
    Selection.MoveRight Unit:=wdCharacter, Count:=1
    Selection.MoveRight Unit:=wdWord, Count:=1, Extend:=wdExtend
    Lot = Selection
 
'Idem pour le champ "nom"
With Selection.Find
    .Forward = True
    .ClearFormatting
    .MatchWholeWord = True
    .MatchCase = False
    .Wrap = wdFindContinue
    .Execute FindText:="ORIGINE"
End With
    Selection.MoveRight Unit:=wdCharacter, Count:=2
    Selection.MoveDown Unit:=wdParagraph, Count:=1, Extend:=wdExtend
    Selection.MoveLeft Unit:=wdCharacter, Count:=1, Extend:=wdExtend
    Nom = Selection
 
    Selection.MoveDown Unit:=wdLine, Count:=1
 
'Je précise que le nom du fichier se nommera sous cette forme
        Fichier = (Nom & "_" & Lot)
 
 
'Je précise la localisation de l'enregistrement et le nom sous lequel il doit être enregistré
            ChangeFileOpenDirectory "\\Serveur-caill\Documents\temporaire\Nicolas\Recherche_BA\Famille\CB_créé"
            'ChangeFileOpenDirectory "\\Serveur-caill\Documents\Contrôles botaniques"
            ActiveDocument.SaveAs FileName:=Fichier, FileFormat:=wdFormatDocument, _
            LockComments:=False, Password:="", AddToRecentFiles:=True, WritePassword _
            :="", ReadOnlyRecommended:=False, EmbedTrueTypeFonts:=False, _
            SaveNativePictureFormat:=False, SaveFormsData:=False, SaveAsAOCELetter:= _
            False
'
'Je confirme à l'utilisateur l'enregistrement
            MsgBox ("Le fichier " & Fichier & ".doc a bien été enregistré dans le répertoire" & vbCrLf & "\\Serveur-caill\Documents\temporaire\Nicolas\Recherche_BA\Famille\CB_Créé")
 
            Else
 
 
        End If
'End If
 
 
'Je ferme le fichier word de base d'où a été lancé le publipostage pour rester uniquement sur le fichier nouvellement créé et nommé
Documents("CB_Famille.doc").Activate
Documents("CB_Famille.doc").Close False
 
End Sub
En espérant que ça puisse aider qq1 d'autre.

Les puristes trouveront surement beaucoup de choses à optimiser mais ça fonctionne.
Je suis par contre preneur pour des améliorations

Merci

Nini
liop49 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/01/2011, 17h03   #4
Invité de passage
 
Inscription : janvier 2011
Messages : 1
Détails du profil
Informations forums :
Inscription : janvier 2011
Messages : 1
Points : 1
Points : 1
Bonjour,

J'arrive bien après la bataille mais...

Si tu veux le fichier global nommé automatiquement, je ne sais pas comment faire.
Par contre si tu veux sauvegarder séparément chaque entrée, tu peux utiliser ceci:

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Sub SaveConsult()
'
' attribue à "nom" la valeur du champ de la 2ème colonne du tableau excel source
nom = ActiveDocument.MailMerge.DataSource.DataFields(2).Value
' Idem pour prénom avec la 3ème colonne
prénom = ActiveDocument.MailMerge.DataSource.DataFields(3).Value
' Idem pour prénom avec la 6ème colonne
consultation_du = ActiveDocument.MailMerge.DataSource.DataFields(6).Value
 
'choisis le dossier destination
ChangeFileOpenDirectory "R:\CONSULTATIONS  EN ATTENTE DE CORRECTION"
'définit le nom d'enregistrement du fichier
ActiveDocument.SaveAs FileName:=nom & " " & prénom & " " & consultation_du & ".doc", FileFormat:=wdFormatDocument
 
End Sub
Il suffit ensuite de changer d'entrée (ligne dans le tableau source) avec les fleches et de répéter l'opération.

Pour désactiver le publipostage des fichiers finaux si nécessaire, il faut les rouvrir et faire "préparation du document principal" et choisir document word normal.

C'est un peu du bricolage mais moi ça répond parfaitement à ce dont j'ai besoin au boulot.
Amenesh est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/01/2011, 18h03   #5
Responsable Word

 
Avatar de Heureux-oli
 
Homme Olivier Lebeau
Contrôleur d'industrie
Inscription : février 2006
Messages : 17 352
Détails du profil
Informations personnelles :
Nom : Homme Olivier Lebeau
Âge : 47
Localisation : Belgique

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

Informations forums :
Inscription : février 2006
Messages : 17 352
Points : 29 265
Points : 29 265
Citation:
Envoyé par Amenesh Voir le message
Bonjour,

J'arrive bien après la bataille mais...

Si tu veux le fichier global nommé automatiquement, je ne sais pas comment faire.
Par contre si tu veux sauvegarder séparément chaque entrée, tu peux utiliser ceci:

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Sub SaveConsult()
'
' attribue à "nom" la valeur du champ de la 2ème colonne du tableau excel source
nom = ActiveDocument.MailMerge.DataSource.DataFields(2).Value
' Idem pour prénom avec la 3ème colonne
prénom = ActiveDocument.MailMerge.DataSource.DataFields(3).Value
' Idem pour prénom avec la 6ème colonne
consultation_du = ActiveDocument.MailMerge.DataSource.DataFields(6).Value
 
'choisis le dossier destination
ChangeFileOpenDirectory "R:\CONSULTATIONS  EN ATTENTE DE CORRECTION"
'définit le nom d'enregistrement du fichier
ActiveDocument.SaveAs FileName:=nom & " " & prénom & " " & consultation_du & ".doc", FileFormat:=wdFormatDocument
 
End Sub
Il suffit ensuite de changer d'entrée (ligne dans le tableau source) avec les fleches et de répéter l'opération.

Pour désactiver le publipostage des fichiers finaux si nécessaire, il faut les rouvrir et faire "préparation du document principal" et choisir document word normal.

C'est un peu du bricolage mais moi ça répond parfaitement à ce dont j'ai besoin au boulot.
salut,

Avec ta méthode, il faut fusionner un document à la fois !
Si j'ai 2 documents, ça va le faire, si j'en ai 10, un peu moins et si j'en ai plus

Une solution plus élégante est décrite là : http://heureuxoli.developpez.com/off...ipostage/#L7-G
__________________
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 !
Heureux-oli est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 20h58.


 
 
 
 
Partenaires

Hébergement Web