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 :

Bloquer l'impression avec une macro [WD-2007]


Sujet :

VBA Word

  1. #1
    Futur Membre du Club
    Inscrit en
    Novembre 2009
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 23
    Points : 8
    Points
    8
    Par défaut Bloquer l'impression avec une macro
    Bonsoir,
    Je voudrais savoir comment bloquer l'impression du document, si il y a rien devant un signet?
    J'ai commencer un code mais ça marche pas!
    Quelqu'un pourrais m'aider pour créer ce code?
    Merci.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Document_BeforePrint(Cancel As Boolean)
        If ActiveDocument.Bookmarks("SignetDate").Range.Text = "" Or ActiveDocument.Bookmarks("SignetDate").Range.Text.Value = "" Then
            Cancel = True
            MsgBox "Remplissez la Date pour pouvoir imprimer"
        End If
    End Sub

  2. #2
    Rédacteur/Modérateur

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

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

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

    T'es certain de la gestion de ton évènement ?

    http://heureuxoli.developpez.com/off...age=page2#L2-C

  3. #3
    Futur Membre du Club
    Inscrit en
    Novembre 2009
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 23
    Points : 8
    Points
    8
    Par défaut
    Salut, je sais pas trop.
    J'ai repris un code que j'ai sur excel que j'ai modifié pour Word.

  4. #4
    Rédacteur/Modérateur

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

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

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

    Voilà un exemple de code qui devrait le faire.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    Public WithEvents appWord as Word.Application
     
    Private Sub appWord_DocumentBeforePrint (ByVal Doc As Document, Cancel As Boolean)
     
       If ActiveDocument.Bookmarks("SignetDate").Range.Text = "" Or ActiveDocument.Bookmarks("SignetDate").Range.Text.Value = "" Then
            Cancel = True
            MsgBox "Remplissez la Date pour pouvoir imprimer"
        End If
     
    End Sub

  5. #5
    Futur Membre du Club
    Inscrit en
    Novembre 2009
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 23
    Points : 8
    Points
    8
    Par défaut
    re,
    J'ai essayé le code ça marche pas !!
    Il faut le mettre dans un module ou dans Thisdocument?

  6. #6
    Rédacteur/Modérateur

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

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

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

    Thisdocument, mais il faut initialiser la gestion.

    Donc, dans l'évènement Document_Open(), on utilise l'objet application.




    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Public WithEvents appWord as Word.Application
     
    Sub Document_Open()
    Set appWord = Word.Application
    End Sub
     
    Private Sub appWord_DocumentBeforePrint (ByVal Doc As Document, Cancel As Boolean)
     
       If ActiveDocument.Bookmarks("SignetDate").Range.Text = "" Or ActiveDocument.Bookmarks("SignetDate").Range.Text.Value = "" Then
            Cancel = True
            MsgBox "Remplissez la Date pour pouvoir imprimer"
        End If
     
    End Sub

  7. #7
    Futur Membre du Club
    Inscrit en
    Novembre 2009
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 23
    Points : 8
    Points
    8
    Par défaut
    Merci Heureux-oli ça marche

  8. #8
    Futur Membre du Club
    Inscrit en
    Novembre 2009
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 23
    Points : 8
    Points
    8
    Par défaut
    J'ai été un peu trop vite.Le code bloque bien l'impression mais quand j'écris devant le "SignetDate" il me bloque quand même l'impression.
    ça marche peut être pas avec un signet?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     Public WithEvents appWord As Word.Application
     
    Sub Document_Open()
    Set appWord = Word.Application
    End Sub
     
    Private Sub appWord_DocumentBeforePrint(ByVal Doc As Document, Cancel As Boolean)
     
       If ActiveDocument.Bookmarks("SignetDate").Range.Text = "" Then
            Cancel = True
            MsgBox "Remplissez la Date pour pouvoir imprimer"
        End If
     
    End Sub

  9. #9
    Rédacteur/Modérateur

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

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

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

    C'est à toi de voir pourquoi, j'ai juste recopié ton code, je n'ai pas regardé ce qu'il était sensé faire.

    Il ne te reste qu'à tester le contenu du signet.

  10. #10
    Futur Membre du Club
    Inscrit en
    Novembre 2009
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 23
    Points : 8
    Points
    8
    Par défaut
    Merci je vais chercher le problème du signet.

  11. #11
    Futur Membre du Club
    Inscrit en
    Novembre 2009
    Messages
    23
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 23
    Points : 8
    Points
    8
    Par défaut
    Bonsoir , j'ai réussi mon code pour bloquer l'impression. Je suis passer par un champ.

    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
    Public WithEvents appWord As Word.Application
     
    Sub Document_Open()
    Set appWord = Word.Application
    End Sub
     
    Private Sub appWord_DocumentBeforePrint(ByVal Doc As Document, Cancel As Boolean)
     
    If ActiveDocument.FormFields("Texte1").Result = "" Then
     
     Cancel = True
            MsgBox "Remplissez la Date pour pouvoir imprimer "
     
        End If
     
    End Sub
    A+

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

Discussions similaires

  1. Problème avec une macro impression
    Par Border_xls dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 08/11/2007, 16h18
  2. tableau dynamique excel crée avec une macro
    Par alex_95 dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 20/03/2006, 13h01
  3. [Excel]Faire une somme avec une macro
    Par Chlo dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 13/01/2006, 20h53
  4. Connaître la taille d'un module avec une macro VBA ou autre
    Par beegees dans le forum Général VBA
    Réponses: 15
    Dernier message: 22/11/2005, 10h47
  5. [VBA Excel] ecrire le caractere " avec une macro
    Par oktopuces dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 09/09/2005, 23h56

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