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 :

Saut de page [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2013
    Messages : 39
    Par défaut Saut de page
    Bonjour,
    J'ai un fichier Excel permettant d'imprimer un rapport. J'aimerais que toute la mises en page se fasse avec une macro. J'ai déjà réussit tout ce que je voulais faire à l'exception que j'aimerais, si possible, ajuster mes sauts de page pour qu'il ne coupe pas un bloc de données. Il est à noter que la grosseur des blocs peut varier aléatoirement. J'aimerais donc pour toutes les pages, si un bloc de données est coupé, que le saut de page se place au dessus du titre "À expédier le ..." afin d'avoir un beau rapport.

    Pouvez-vous m'aider ?

    Merci !
    Fichiers attachés Fichiers attachés

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bonjour,

    Je pense que ceci devrait t'aider

    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
    Sub SautDePage()
        Dim I As Long, J As Long
     
        Application.ScreenUpdating = False
     
        ActiveWindow.View = xlPageBreakPreview
        ActiveSheet.ResetAllPageBreaks
     
        For I = 1 To ActiveSheet.HPageBreaks.Count
            For J = ActiveSheet.HPageBreaks(I).Location.Row - 1 To 3 Step -1
                If InStr(1, Range("A" & J), "expédier") > 0 Then
                    Set ActiveSheet.HPageBreaks(1).Location = Range("A" & J)
                    Exit For
                End If
            Next
        Next
     
        ActiveWindow.View = xlNormalView
        Application.ScreenUpdating = True
    End Sub

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2013
    Messages : 39
    Par défaut
    J'ai fait une petite correction, probablement une erreur de frappe, j'ai remplacé le 1 par I :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set ActiveSheet.HPageBreaks(1).Location = Range("A" & J)
    par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set ActiveSheet.HPageBreaks(I).Location = Range("A" & J)
    Sinon, wow !!! Franchement, je n'aurais jamais réussis à pondre un truc du genre ! Je te remercie infiniment !

  4. #4
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Effectivement, c'était un I qui devait être là.

    J'oubliais aussi de mentionner qu'il se pourrait qu'un nouvelle page s'ajoute s'il y a beaucoup de saut de pages. Disons qu'au début tu as 10 pages, il se peut qu'après avoir insérer les 9 sauts de pages, tu te retrouves avec une 11e page qui ne serait pas prise en compte.

    Il faudra y ajouter une autre boucle, ce qui donnerait quelque chose comme:

    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
        nbPageBr = Activesheet.HPageBreaks.Count
     
        For I = 1 To nbPageBr
            For J = Activesheet.HPageBreaks(I).Location.Row - 1 To 3 Step -1
                If InStr(1, Range("A" & J), "expédier") > 0 Then
                    Set Activesheet.HPageBreaks(I).Location = Range("A" & J)
                    Exit For
                End If
            Next
        Next
     
        If nbPageBr < Activesheet.HPageBreaks.Count Then 'vérifier si c'a changé...
            nbPageBr = Activesheet.HPageBreaks.Count
            For J = Activesheet.HPageBreaks(nbPageBr).Location.Row - 1 To 3 Step -1
                If InStr(1, Range("A" & J), "expédier") > 0 Then
                    Set Activesheet.HPageBreaks(nbPageBr).Location = Range("A" & J)
                    Exit For
                End If
            Next
        End If

  5. #5
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    39
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2013
    Messages : 39
    Par défaut
    Dans ta 2e boucle, tu as mis Range("C") au lieu de A... est-ce voulu ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     If nbPageBr < Activesheet.HPageBreaks.Count Then 'vérifier si c'a changé...
            nbPageBr = Activesheet.HPageBreaks.Count
            For J = Activesheet.HPageBreaks(nbPageBr).Location.Row - 1 To 3 Step -1
                If InStr(1, Range("C" & J), "expédier") > 0 Then
                    Set Activesheet.HPageBreaks(nbPageBr).Location = Range("A" & J)
                    Exit For
                End If
            Next
        End If

  6. #6
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Non, c'est bien A...
    Erreur de copie.
    désolé

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

Discussions similaires

  1. [langage] convertir 0x0c en saut de page ?
    Par narmataru dans le forum Langage
    Réponses: 5
    Dernier message: 26/01/2005, 16h41
  2. [Rave Report] les sauts de page
    Par Isa31 dans le forum Rave
    Réponses: 4
    Dernier message: 14/10/2004, 18h51
  3. [VBA] Saut de page...
    Par _Maniak dans le forum Général VBA
    Réponses: 5
    Dernier message: 24/09/2004, 15h26
  4. Réponses: 7
    Dernier message: 05/12/2003, 10h14
  5. [Delphi6] Saut de page
    Par Seb328Ci dans le forum QuickReport
    Réponses: 1
    Dernier message: 02/10/2003, 12h36

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