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 :

Connaitre le nombre de page d'un document word [WD-2003]


Sujet :

VBA Word

  1. #1
    Membre chevronné Avatar de Krovax
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 888
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 888
    Points : 2 168
    Points
    2 168
    Par défaut Connaitre le nombre de page d'un document word
    Bonjour,

    On a besoin de connaitre le nombre de page de chacun des fichiers word d'un dossier. Boucler sur le contenu du répertoire pas de problème. Le problème est de récupérer le nombre de page. Voici le code utilisé

    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
    'Necessite d'activer la reference Microsoft Shell Controls and Automation
    '
    Dim objShell As Object, strFileName As Object
    Dim objFolder As Folder
    Dim Resultat As String
    Dim i As Byte
     
    Set objShell = CreateObject("Shell.Application")
    'repertoire cible
    Set objFolder = objShell.nameSpace("C:\Test")
     
    'boucle sur tous les elements du repertoire
    For Each strFileName In objFolder.Items
      'pour que les sous dossiers ne soient pas pris en comptes
      If strFileName.isFolder = False Then
      Resultat = objFolder.getDetailsOf(strFileName, 13)
      MsgBox Resultat
      End If
    Next
    End Sub
    Le problème étant que par cette méthode on obtient toujours 1 page (manuellement on a le même résultat) quelque soit le nombre de page du fichier...

    Si quelqu'un a une solution

    Ps : la version Ouvrir compter fermer pose quelque souci, le code va tourner sur une espèce de vieux machin, et du coup l'ouverture ne semble pas s'achever avant le passage a la ligne de code suivante (en mode pas a pas ca passe tout seul )

    Le code utilisé

    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
    21
    22
    23
    24
    25
    26
    27
    28
    Sub OuvrirWord()
    Dim nbpage As Integer, i As Integer, j As Long, k As Integer, trouve As Integer
    Dim nomdoc As String
     
    Application.ScreenUpdating = False
     
    For i = 2 To 5
      trouve = 0
      nomdoc = "C:\Test\Doc" & i & ".doc"
      With Application.FileSearch
          .FileName = "Doc" & i & ".doc"
          .LookIn = "C:\Test\"
          .Execute
          trouve = .FoundFiles.Count
      End With
         If trouve >= 1 Then
          For k = 1 To trouve
              set docu=Documents.Open Application.FileSearch.FoundFiles(k)
              DoEvents 'qui n'a rien changé a son arrivé
              nbpage = docu.BuiltInDocumentProperties("Number of Pages").Value
              If nbpage <= 7 Then
                 Documents(docu.Name).Close savechanges:=False
              End If  
          Next k
         End If
    Next i
    Application.ScreenUpdating = True
    End Sub
    « Il n'y a pas de recette miracle qui permet aux gens d’écrire des programmes corrects sans avoir à réfléchir. Il faut apprendre aux gens comment réfléchir »

  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,

    Perso, je préfère utiliser le FSO (FileSystemObject) pour parcourir les objets d'un répertoire.
    Et pour récupérer les informations d'un fichier Word, le DSO permet de ne pas ouvrir le document avec l'application.

    Maintenant, tu ne nous dis pas si tu pars de Word ou d'un autre logiciel ?

    Pour le DSO :
    http://heureuxoli.developpez.com/off.../variables/#L5

    Pour le FSO :
    http://warin.developpez.com/access/fichiers/
    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
    Membre chevronné Avatar de Krovax
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 888
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 888
    Points : 2 168
    Points
    2 168
    Par défaut
    Bonjour, je lance la macro a partir de word, par contre avec DSO on obtient toujours une seule page. Après il y a peut être une erreur dans le code

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Sub proprietesFichiersDso()
     
    Dim oDso As DSOFile.OleDocumentProperties
    Dim resultat As String
     
    Set oDso = New DSOFile.OleDocumentProperties
     
    oDso.Open sfilename:="C:\Test\Doc4.doc"
    resultat = ActiveDocument.BuiltInDocumentProperties(wdPropertyPages)
    MsgBox resultat
    End Sub
    « Il n'y a pas de recette miracle qui permet aux gens d’écrire des programmes corrects sans avoir à réfléchir. Il faut apprendre aux gens comment réfléchir »

  4. #4
    Membre chevronné Avatar de Krovax
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 888
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 888
    Points : 2 168
    Points
    2 168
    Par défaut
    Le code finalement utilisé

    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    Sub OuvrirWord()
    Dim i As Integer, derpage As Integer, k As Integer, trouve As Integer
    Dim nomdoc As String
     
    Application.ScreenUpdating = False
     
    For i = 2 To 5
    trouve = 0
    nomdoc = "C:\Test\Doc" & i & ".doc"
    With Application.FileSearch
      .FileName = "Doc" & i & ".doc"
      .LookIn = "C:\Test"
      .Execute
      trouve = .FoundFiles.Count
    End With
     
    If trouve >= 1 Then
      For k = 1 To trouve
          Documents.Open Application.FileSearch.FoundFiles(k)
          Documents(Application.FileSearch.FoundFiles(k)).Activate
     
          With ActiveDocument
              Selection.EndKey Unit:=wdStory
              derpage = Selection.Information(wdActiveEndPageNumber)
          End With
     
          If derpage <= 7 Then
              Documents(Application.FileSearch.FoundFiles(k)).Close savechanges:=False
          End If
      Next k
    End If
     
    Next i
    Application.ScreenUpdating = True
    « Il n'y a pas de recette miracle qui permet aux gens d’écrire des programmes corrects sans avoir à réfléchir. Il faut apprendre aux gens comment réfléchir »

  5. #5
    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,

    Surprenant, je viens d'essayer
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
     
    Sub proprieteDocument()
    Dim oDSO As DSOFile.OleDocumentProperties
    Dim oFSO As FileSystemObject
    Dim ofol As Folder
    Dim ofil As File
    Dim prop As DSOFile.SummaryProperties
    Dim oDlg As FileDialog
     
    Set oDlg = Application.FileDialog(msoFileDialogFolderPicker)
    Set oFSO = New FileSystemObject
    Set oDSO = New DSOFile.OleDocumentProperties
    oDlg.Show
     
    Set ofol = oFSO.GetFolder(oDlg.SelectedItems(1))
     
     
     
     
    For Each ofil In ofol.Files
     
     
    If Right(ofil.Name, 4) = "docm" Or Right(ofil.Name, 4) = "docx" Then
    oDSO.Open sFileName:=ofil.Name
    Debug.Print ofil.Name & " - " & oDSO.SummaryProperties.PageCount
    oDSO.Close
    End If
     
     
    Next ofil
    Set oDlg = Nothing
    Set ofol = Nothing
    Set oFSO = Nothing
    Set oDSO = Nothing
     
     
    End Sub
    Et tout fonctionne correctement.
    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. [XL-2003] Connaitre le nombre de page d'un document word
    Par Krovax dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 07/07/2009, 22h21
  2. Réponses: 1
    Dernier message: 28/04/2009, 11h49
  3. Connaitre le nombre de page d'un fichier Word
    Par abbd dans le forum Services Web
    Réponses: 1
    Dernier message: 23/02/2009, 11h26
  4. Détection de nombres de pages dans un documents Word,Pdf,Xsl ..
    Par moez.mhiri dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 13/01/2009, 09h23
  5. Nombre de page d'un document word
    Par DonKnacki dans le forum VBA Word
    Réponses: 3
    Dernier message: 18/06/2007, 13h18

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