Rubrik: Dateisystem · Dateien - allgemein | VB-Versionen: VB2005, VB2008 | 29.12.10 |
Dateien mittels Fortschrittsanzeige und Windows Dialog kopieren (SHFileOperation) Eine Funktion, mit der sich eine oder mehrerer Dateien mittels Windows-Dialog und Fortschrittsanzeige kopieren lassen. | ||
Autor: Dieter Otter | Bewertung: | Views: 15.262 |
www.tools4vb.de | System: Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
Mittels der SHFileOperation-Funktion aus dem Windows API lässt sich u.a. auch der Windows-Kopier-Dialog in der eigenen Anwendung verwenden. Gerade bei großen oder sehr vielen Dateien ist es sinnvoll, dem Benutzer den Kopierfortschritt entsprechend anzuzeigen. Und genau das erledigt in diesem Fall "Windows" für uns. Über den Parameter "Overwrite" können Sie zudem festlegen, ob der Benutzer selbst entscheiden soll, wenn bereits vorhandene Dateien überschrieben werden sollen.
' API-Deklarationen Private Declare Function SHFileOperation Lib "shell32.dll" _ Alias "SHFileOperationA" ( _ ByRef lpFileOp As SHFILEOPSTRUCT) As Integer Private Structure SHFILEOPSTRUCT Dim hwnd As IntPtr Dim wFunc As Integer Dim pFrom As String Dim pTo As String Dim fFlags As Short Dim fAnyOperationsAborted As Boolean Dim hNameMappings As Integer Dim lpszProgressTitle As String End Structure Private Const FN_COPY As Integer = &H2& Private Const FnF_RENAMEONCOLLISION = &H8& Private Const FnF_MULTIDESTFILES = &H1& Private Const FnF_FILESONLY = &H80&
''' <summary> ''' Kopiert eine oder mehrere Dateien mit Hilfe des Windows Dialogs ''' </summary> ''' <param name="SourceFile">Quelldatei(en)</param> ''' <param name="DestPath">Ziel-Ordner</param> ''' <param name="Overwrite">True, wenn vorhandene Dateien überschrieben ''' werden sollen, andernfalls False.</param> ''' <returns>Mehrere Dateien müssen mit 2 x Chr(0) voneinander getrennt ''' übergeben werden.</returns> Public Function CopyFileShell(ByVal SourceFile As String, _ ByVal DestPath As String, _ ByVal Overwrite As Boolean) As Boolean Dim SFO As New SHFILEOPSTRUCT Dim Flags As Short = 0 ' Überschreiben? If Overwrite Then Flags = Flags Or FnF_RENAMEONCOLLISION ' Mehrere Dateien kopieren If SourceFile.Contains(Chr(0) & Chr(0)) Then Flags = Flags Or FnF_MULTIDESTFILES End If If SourceFile.Contains("*") Then Flags = Flags Or FnF_FILESONLY End If With SFO .wFunc = FN_COPY .pFrom = SourceFile.TrimEnd(Chr(0)) & Chr(0) & Chr(0) .pTo = DestPath .fFlags = Flags End With Return (SHFileOperation(SFO) = 0) End Function
Aufrufbeispiel:
' alle Dateien im Ordner D:\temp nach D:\temp1 kopieren Dim Result As Boolean = CopyFileShell("D:\temp\*.*", "D:\temp1", False)
' Einzelne Datei kopieren. Falls vorhanden immer überschreiben. Dim Result As Boolean = CopyFileShell("D:\temp\MyFile.xyz", "D:\temp1", True)