Hallo,
ich habe mehrere PDF Dateien im Adobe Acrobat Reader geöffnet.
Ich möchte die aktuell geöffnete PDF abspeichern und den Dateinamen ändern in dem ich das heutige Datum mit _YYYYMMDD im Dateinamen am Ende ergänze eben nicht über Speichern unter, sondern über einen Button (z.B. Schnellzugriffsleiste)in einer Excel Arbeitsmappe, die immer auf ist.
Die geöffnete PDF Datei finden kann ich mit folgendem Code. Dabei werden aber nur die Titelleisten der geöffneten Windows ausgelesen. Aber mir fehlt der Pfad zu dieser Datei, damit ich speichern könnte.
Hat einer eine Idee wie ich noch den Pfad der aktuell geöffneten PDF Datei bestimmen kann?
' API Funktionen
Private Declare Function EnumWindows Lib "user32" (ByVal lpEnumFunc As Long, ByVal lParam As Long) As Boolean
Private Declare Function GetWindowText Lib "user32" Alias "GetWindowTextA" (ByVal hWnd As Long, ByVal lpString As String, ByVal cch As Long) As Long
Private Declare Function GetWindowTextLength Lib "user32" Alias "GetWindowTextLengthA" (ByVal hWnd As Long) As Long
Public strDatei As String
Public Sub SucheFenster()
strDatei = "Keine PDF Datei geöffnet"
EnumWindows AddressOf FindWindow, 0&
MsgBox "Geöffnete Datei: " + strDatei, , "Hinweis"
End Sub
Private Function FindWindow(ByVal lngHwnd As Long, ByVal lngParam As Long) As Boolean
Dim strTemp As String, lngRetVal As Long, p As Long
lngRetVal = GetWindowTextLength(lngHwnd)
strTemp = Space(lngRetVal)
GetWindowText lngHwnd, strTemp, lngRetVal + 1
If lngRetVal <> 0 Then
p = InStr(UCase(strTemp), ".PDF")
If (p > 0) Then strDatei = Left(strTemp, p + 3): FindWindow = False: Exit Function
End If
FindWindow = True
End Function |