Live-Forum - Die aktuellen Beiträge
Anzeige
Archiv - Navigation
964to968
Aktuelles Verzeichnis
Verzeichnis Index
Übersicht Verzeichnisse
Vorheriger Thread
Rückwärts Blättern
Nächster Thread
Vorwärts blättern
Anzeige
HERBERS
Excel-Forum (Archiv)
20+ Jahre Excel-Kompetenz: Von Anwendern, für Anwender
964to968
964to968
Aktuelles Verzeichnis
Verzeichnis Index
Verzeichnis Index
Übersicht Verzeichnisse
Inhaltsverzeichnis

öffnen, aktualisieren, speichen, schließen

öffnen, aktualisieren, speichen, schließen
01.04.2008 21:12:00
wossi
Hallo Leute,
folgendes möchte ich bewirken. bei click auf einen Button, soll sich ein Fenster(Verzeichnisbaum) öffnen, ich wähle mir ein Verzeichnis aus, und nun sollen alle Dateien darin nacheinander geöffnet, verknüpfungen etc. aktualisiert werden, speichern und wieder schließen.
Habe in dem FAQ hier auch was gefunden, weiß nur nicht wie ich s zusammenbringe....
Verzeichnis auswählen:
StandardModule: basMain
Option Private Module
Public Type BROWSEINFO
hOwner As Long
pidlRoot As Long
pszDisplayName As String
lpszTitle As String
ulFlags As Long
lpfn As Long
lParam As Long
iImage As Long
End Type
Declare

Function SHGetPathFromIDList Lib "shell32.dll" _
Alias "SHGetPathFromIDListA" (ByVal pidl As Long, ByVal pszPath As String) As Long
Declare 

Function SHBrowseForFolder Lib "shell32.dll" _
Alias "SHBrowseForFolderA" (lpBrowseInfo As BROWSEINFO) As Long


Sub DirAuswahl()
Dim sMsg As String, sPath As String
sMsg = "Wählen Sie bitte einen Ordner aus:"
sPath = getdirectory(sMsg)
If sPath  "" Then MsgBox sPath
End Sub



Function getdirectory(Optional msg) As String
Dim bInfo As BROWSEINFO
Dim Path As String
Dim r As Long, x As Long, pos As Integer
bInfo.pidlRoot = 0&
If IsMissing(msg) Then
bInfo.lpszTitle = "Wählen Sie bitte einen Ordner aus."
Else
bInfo.lpszTitle = msg
End If
bInfo.ulFlags = &H1
x = SHBrowseForFolder(bInfo)
Path = Space$(512)
r = SHGetPathFromIDList(ByVal x, ByVal Path)
If r Then
pos = InStr(Path, Chr$(0))
getdirectory = Left(Path, pos - 1)
Else
getdirectory = ""
End If
End Function


öfnnen, aktualissieren, speichern, schließen:
StandardModule: Modul1


Sub OeffnenSchliessen()
Dim iRow As Integer
Dim sFile As String
On Error GoTo ERRORHANDLER
Application.ScreenUpdating = False
Application.EnableEvents = False
iRow = 1
Do Until IsEmpty(Cells(iRow, 1))
sFile = Cells(iRow, 1).Value
If Dir(sFile)  "" Then
Workbooks.Open _
Filename:=sFile, _
updatelinks:=True
ActiveWorkbook.Close savechanges:=True
End If
iRow = iRow + 1
Loop
ERRORHANDLER:
Application.EnableEvents = True
Application.ScreenUpdating = True
End Sub


Kann mir jemand helfen, das so zusammen zubringen, dass es nach meinen Vorstellungen funktioniert?
Besten Dank.
Gruß
wossi

2
Beiträge zum Forumthread
Beiträge zu diesem Forumthread

Betreff
Datum
Anwender
Anzeige
AW: öffnen, aktualisieren, speichen, schließen
02.04.2008 10:15:00
UweD
Hallo
ich mach das so:


      
Sub alle_Dateien_Verzeichnis() '
    Dim dlg As FileDialog
    
Dim Si, Ext$, Datei$
    
Set dlg = Application.FileDialog(msoFileDialogFolderPicker) 'Verzeichnis wählen
    If dlg.Show = True Then
        
For Each Si In dlg.SelectedItems 'Die Abfrage für den selektierten Eintrag
            Ext = "*.xls"       'Dateiextension ggf. anpassen
            Datei = Dir(Si & "\" & Ext)
            
Do
                Workbooks.Open FileName:=Si & 
"\" & Datei
                
'mach was damit
                Workbooks(Datei).Close SaveChanges:=True
                Datei = Dir() 
' nächste Datei
            Loop While Len(Datei) > 0
        
Next
    
End If
End Sub 


Gruß UD

Anzeige
AW: öffnen, aktualisieren, speichen, schließen
02.04.2008 20:14:08
wossi
HAllo Uwe,
danke dafür. ICh werde es gleich mal ausprobieren.
Gruß,
wossi

300 Forumthreads zu ähnlichen Themen

Anzeige
Anzeige
Anzeige

Beliebteste Forumthreads (12 Monate)

Anzeige

Beliebteste Forumthreads (12 Monate)

Anzeige
Anzeige
Anzeige