在Excel中怎样用VBA批量统计PDF页数,大神们,帮帮忙,万分感谢。

发布网友 发布时间:2024-10-22 15:10

我来回答

2个回答

热心网友 时间:2024-11-07 06:49

试试下面的代码,在网上找的:

Sub pdfpage()
    Dim AcroApp As Acrobat.CAcroApp
    Dim numPages As Integer
    Dim PD1 As Acrobat.CAcroPDDoc
      
    Set AcroApp = CreateObject("AcroExch.App")
    Set PD1 = CreateObject("AcroExch.PDDoc")
      
    Dim mydialog As FileDialog
    Dim i As Integer, sFile As String
    
    Set mydialog = Application.FileDialog(msoFileDialogFilePicker)
    
    With mydialog
        .Filters.Clear '清除所有文件筛选器中的项目
        .Filters.Add "所有PDF文件", "*.pdf", 1 '增加筛选器的项目为所有pdf文件
        .AllowMultiSelect = True '允许多项选择
        .Show
        If .SelectedItems.Count = 0 Then
            MsgBox "没有选择任何文件!", vbExclamation + vbOKOnly, "提示"
            Exit Sub
        End If
        
        For i = 1 To .SelectedItems.Count
            sFile = .SelectedItems(i)
            Range("a" & i) = sFile
            PD1.Open (sFile)
            Range("b" & i) = PD1.GetNumPages()
            PD1.Close
        Next
        MsgBox "文件处理完毕!" & vbCrLf & vbCrLf & "共处理了 " & .SelectedItems.Count & " 个文件。", vbInformation + vbOKOnly, "提示"
    End With
    AcroApp.Exit
    Set AcroApp = Nothing
    Set PD1 = Nothing
End Sub

追问谢谢,这个运行不了。

追答

网页链接 看看这个链接里的内容。代码可能有错误

热心网友 时间:2024-11-07 06:50

Excel对PDF就好像鸡同鸭讲,不是一个系统怎么统计?

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com