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 :

supprimer les sauts de page dans word


Sujet :

VBA Word

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 10
    Points : 6
    Points
    6
    Par défaut supprimer les sauts de page dans word
    Bonjour,

    je travaille sur un export .txt que je met en forme avec word. (copy/paste puis mise en forme)
    Malheureusement, lorsque je fait ma mise en page je me retrouve avec pleins de saut de page que je dois supprimer manuellement, et cela prend un temps fou.

    Je n'arrive pas a trouver de solution pour supprimer tous les sauts de pages de mon document.

    En plus de cela au niveau VBA word je connais rien du tout, j'ai juste réussi à fairte une macro qui met en page à l'aide de l'enregistreur, puis je defini ma police et ma taille de caractere.


    Comment faire pour supprimer cesmaudits suats de page dans tout le document?

    Si je fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Selection.WholeStory
    Selection.DeleteBreak Type:=wdPageBreak
    ca ne marche pas car la propriété delete ne peut pas etre affecter à l'objet break, c bien ca?

    Que vaut il mieux faire:
    1-une boucle qui repere tous les sauts de page puis les effaces (mais comment faire une boucle et dire d'aller a la page suivante dans Word?)
    2-Ou alors selectionner tout le doc et supprimer touts les objets break de type pagebreak?

    Merci beaucoup pour votre aide

  2. #2
    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
    Salut,

    Pourquoi faire en VBA ce que l'interface peut faire ?

    Jette un oeil sur ce tuto, je pense qu'il va t'aider.
    http://sepia.developpez.com/office/w...cherremplacer/
    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 !

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 10
    Points : 6
    Points
    6
    Par défaut
    salut heureux oli,

    effectivement ca alair de fonctionner je ne savais pas que cete fonction été possible.
    Enfin j'ai tester sur Wd2007 je verrais demain o taf sur Wd2000.
    Mais bon c qd meme de la balle, merci beaucoup, je vais gagner un temps fou.

    A part cela j'ai une autre question.

    Avec cet export je doit imprimer certaine page en fonction des numero de compte qui apparaisse decu (je fais de la compta). En principe toujours les meme compte, sachant que pour les exeption sj epourrais bien les faire manuellement. Mais bon j'en ai une trentaine que je fais tous les jours et qui n'apparaissent bien evidement pas successivement.

    Ex: je veux sortir le compte 351210586

    jusqua maintenant je faisait un Ctrl+F (351210586) dans mon document puis j'imprime la page en cours.

    Si je fait un truc du style
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    Sub print ()
    Selection.Find.ClearFormatting
        With Selection.Find
            .Text = "351210586"
            .MatchWholeWord = True
        End With
        Selection.Find.Execute
        Application.PrintOut FileName:="", Range:=wdPrintCurrentPage, Item:= _
            wdPrintDocumentContent, Copies:=1, Pages:=""
    End Sub
    est ce que cela peut marcher si je met les Find les uns a la suite des autres?
    sans boucle? Acondition de faire le ClearFormating a chaque fois?
    Si non , comment dire va chercher les comptes n°xxxxx, yyyyyy, zzzzz).
    Puis imprime (xxxxxx; yyyyy; zzzzz)

    Merci beaucoup.

  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
    Salut,

    Si tu mets les Find les uns à la suite des autres, tu dois savoir combien tu vas en avoir sur le document.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Dim bootrouv As Boolean
     
    Do 
    Selection.Find.ClearFormatting
        With Selection.Find
            .Text = "351210586"
            .MatchWholeWord = True
            bootrouv = .Execute
        End With
        Application.PrintOut FileName:="", Range:=wdPrintCurrentPage, Item:= _
            wdPrintDocumentContent, Copies:=1, Pages:=""
    loop While bootrouv
    en clair :
    Lorsque l'on fait une recherche, si elle est fructueuse, .execute renvoie vrai
    Je stocke cette valeur dans une variable et je dis que tant que cette variable est vraie on recommence.
    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. Réponses: 0
    Dernier message: 27/04/2014, 19h14
  2. [VBA-E] Imposer les sauts de page dans la mise en forme
    Par lucarno dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 17/05/2007, 10h51
  3. [VB6]supprimer un saut de page dans Word
    Par Yal17 dans le forum VB 6 et antérieur
    Réponses: 25
    Dernier message: 14/06/2006, 12h21
  4. VBA : Insertion d'un saut de page dans WORD
    Par Actarus69 dans le forum VBA Word
    Réponses: 1
    Dernier message: 25/04/2006, 13h05

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