Comment compter le nombre de pages dans des fichiers PDF à l’aide d’Excel ?
Si vous avez plusieurs fichiers PDF dans un dossier et que vous souhaitez lister leurs noms accompagnés du nombre de pages correspondant dans Excel, une simple macro VBA vous permet de le faire en toute simplicité. Ce tutoriel vous accompagne pas à pas pour extraire et afficher rapidement les noms de vos fichiers PDF ainsi que leur nombre de pages directement dans une feuille de calcul Excel.
Afficher les noms des Fichiers PDF et leur nombre de pages dans Excel avec VBA
Afficher les noms des Fichiers PDF et leur nombre de pages dans Excel avec VBA
Le code VBA suivant vous permet d’afficher, dans une feuille de calcul, tous les noms des fichiers PDF ainsi que leur nombre de pages. Voici la marche à suivre :
1. Ouvrez une feuille de calcul dans laquelle vous souhaitez récupérer les noms des fichiers PDF ainsi que leur nombre de pages.
2. Maintenez enfoncées les touches « ALT » + « F11 » pour ouvrir la fenêtre « Microsoft Visual Basic pour Applications ».
3. Cliquez sur « Insertion » > « Module », puis collez la macro suivante dans la fenêtre du module.
Code VBA : lister tous les noms des Fichiers PDF et leur nombre de pages dans la feuille de calcul :
Sub Test()
Dim I As Long
Dim xRg As Range
Dim xStr As String
Dim xFd As FileDialog
Dim xFdItem As Variant
Dim xFileName As String
Dim xFileNum As Long
Dim RegExp As Object
Set xFd = Application.FileDialog(msoFileDialogFolderPicker)
If xFd.Show = -1 Then
xFdItem = xFd.SelectedItems(1) & Application.PathSeparator
xFileName = Dir(xFdItem & "*.pdf", vbDirectory)
Set xRg = Range("A1")
Range("A:B").ClearContents
Range("A1:B1").Font.Bold = True
xRg = "File Name"
xRg.Offset(0, 1) = "Pages"
I = 2
xStr = ""
Do While xFileName <> ""
Cells(I, 1) = xFileName
Set RegExp = CreateObject("VBscript.RegExp")
RegExp.Global = True
RegExp.Pattern = "/Type\s*/Page[^s]"
xFileNum = FreeFile
Open (xFdItem & xFileName) For Binary As #xFileNum
xStr = Space(LOF(xFileNum))
Get #xFileNum, , xStr
Close #xFileNum
Cells(I, 2) = RegExp.Execute(xStr).Count
I = I + 1
xFileName = Dir
Loop
Columns("A:B").AutoFit
End If
End Sub
4. Après avoir collé le code, appuyez sur la touche « F5 » pour exécuter la macro. La fenêtre « Parcourir » s’ouvre alors : veuillez sélectionner le dossier contenant les fichiers PDF dont vous souhaitez lister les noms et compter les pages (voir la capture d’écran).

5. Cliquez ensuite sur le bouton « OK » : les noms de tous les fichiers PDF ainsi que leur nombre de pages sont insérés dans la feuille de calcul active, comme illustré dans la capture d’écran suivante :

Meilleurs outils de productivité Office
Boostez vos compétences Excel avec Kutools pour Excel et découvrez une efficacité inégalée.Kutools pour Excel propose plus de 300 fonctionnalités avancées pour améliorer votre productivité et Gagner du temps.Cliquez ici pour obtenir la fonctionnalité dont vous avez le plus besoin...
Office Tab apporte une interface à onglets à Office et rend votre travail bien plus facile
- Activez l’édition et la lecture par onglets dans Word, Excel, PowerPoint, Publisher, Access, Visio et Project.
- Ouvrez et créez plusieurs documents dans de nouveaux onglets de la même fenêtre, plutôt que dans de nouvelles fenêtres.
- Augmente votre productivité de 50 % et vous fait économiser des centaines de clics de souris chaque jour !
Tous les compléments Kutools. Un seul installateur
Kutools for Office regroupe les compléments pour Excel, Word, Outlook et PowerPoint, ainsi que Office Tab Pro, ce qui en fait le choix idéal pour les équipes travaillant à travers les applications Office.
- Suite tout-en-un— Compléments Excel, Word, Outlook et PowerPoint + Office Tab Pro
- Un seul installateur, une seule licence— installation en quelques minutes (compatible MSI)
- Fonctionne mieux ensemble— productivité optimisée dans toutes les applications Office
- Essai gratuit de 30 jours avec toutes les fonctionnalités— aucune inscription, aucune carte bancaire
- Meilleur rapport qualité-prix— économisez par rapport à l’achat de compléments individuels