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 :

[VBA-E]BeforePrint, ok. Mais, AfterPrint ?


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Février 2007
    Messages : 106
    Par défaut [VBA-E]BeforePrint, ok. Mais, AfterPrint ?
    Bonjour,

    J'utilise la fonction "BeforePrint" qui m'est bien pratique pour faire une mise en page spécial. Mais mon problème c'est que après l'impression, la mise en page reste ce qui ne m'arrange pas. Pour le moment j'ai résolu mon problème d'une autre façon mais pas très pratique, celà m'oblige à changer d'onglet pour revenir à mon onglet.

    Exite-t-il une solution qui serait du style "AfterPrint" ?Oui, je sais la fonction direct AfterPrint n'existe pas ( ou je ne l'ai jamais vu ).


    Si quelqu'un à une solution, je suis preneur.

    Merci beaucoup.

    Srame

  2. #2
    Membre Expert Avatar de wilfried_42
    Homme Profil pro
    Auto-entrepreneur
    Inscrit en
    Novembre 2006
    Messages
    1 427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Auto-entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 427
    Par défaut
    bonjour scram

    le seul moyen que j'utilise c'est de gérer l'impression du debut à la fin

    Lancer soi meme l'impression par macro et ensuite tu traites comme tu veux


    bon apres midi

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Février 2007
    Messages : 106
    Par défaut
    Bonjour wilfried,

    Sauf que mes modifications ne sont pas au niveau de l'impression elle-même, mais au niveau de ma feuille, Je cache des cellules pour en faire apparaitre d'autres.

    Et je voudrais que après l'impression ma feuille redevienne normale.

    Voici mon code d'impression :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Private Sub Workbook_BeforePrint(Cancel As Boolean)
        Dim F As Worksheet, MaskLign
            For Each F In ThisWorkbook.Sheets
                If F.name Like "CHOUT*" Then
                    MaskLign = "6:6"
                    If F.name Like "*TNL*" Then MaskLign = "7:7"
                        F.Unprotect
                            F.Rows(MaskLign).EntireRow.Hidden = True
                            F.Range(MaskLign).Offset(1, 0).EntireRow.Hidden = False
                        F.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True
                End If
            Next
    End Sub
    Et mon code pour le retour à la normale :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub Worksheet_Activate()
    MaskLign = "6:6"
        If ActiveSheet.name Like "*TNL*" Then MaskLign = "7:7"
            ActiveSheet.Unprotect
                ActiveSheet.Rows(MaskLign).EntireRow.Hidden = False
                ActiveSheet.Range(MaskLign).Offset(1, 0).EntireRow.Hidden = True
            ActiveSheet.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True
    End Sub
    Voilà, c'est peut-être un peu trop compliqué comme code, mais ça fonctionne super bien.

  4. #4
    Membre Expert Avatar de wilfried_42
    Homme Profil pro
    Auto-entrepreneur
    Inscrit en
    Novembre 2006
    Messages
    1 427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Auto-entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 427
    Par défaut
    re:

    je ne t'ai pas dit de changer tes modules, je t'ai dit de controler l'impression

    Au lieu de la lancer du menu, ou d'une icone, tu la lances d'un bouton

    Worksheets("Imprim").printout
    ta routine beforeprint se lance normalement
    apres tu ecris ce que tu veux

    cordialement

Discussions similaires

  1. [XL-2007] VBA le code compile mais ne s'exécute pas
    Par daffy85 dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 05/05/2014, 10h41
  2. Réponses: 3
    Dernier message: 15/01/2008, 14h59
  3. [VBA-E] excel minimisé mais user form visible
    Par bill7 dans le forum Macros et VBA Excel
    Réponses: 24
    Dernier message: 22/04/2007, 15h30
  4. [VBA-E] find oui mais quelle ligne ?
    Par SpaceFrog dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 16/10/2006, 15h03
  5. Utiliser SQL = (Comme "blabla*") mais En VBA sur I
    Par samlepiratepaddy dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 28/10/2005, 19h30

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