Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

Datei auf Festplatte per VBA suchen und löschen ( access 2010)

Frage Microsoft Microsoft Office

Mitglied: thomas1972

thomas1972 (Level 1) - Jetzt verbinden

05.06.2014 um 07:58 Uhr, 6733 Aufrufe, 5 Kommentare

Hallo,

ich weis leider nicht wie es am bestehn hinbekomme,

Ich möchte über Access per VBA bei Klick auf einem Button im Hintergrund nach einer Datei auf der Festplatte suchen lassen (am besten mit Platzhalter *test*.exe)
und sollte diese gefunden werden soll diese ohne nachfrage gelöscht (mir bekannt nur der Kill Befehl)

Welche möglichkeit habe ich dieses umzusetzen?

Würde mich über Hilfe freuen.

Mitglied: colinardo
05.06.2014, aktualisiert um 11:43 Uhr
Moin,
erster Link unter deinem Post ("Diese Inhalte könnten dich auch interessieren"):
http://www.administrator.de/forum/access-2010-vba-pr%c3%bcfen-ob-bestim ...
Wenn man Ordner Rekursiv durchsuchen möchte kann man es über eine Rekursive Funktion machen, das kann ich aber nur über einen begrenzten Ordnerbaum empfehlen und nicht über eine ganze Festplatte. Siehe dazu: http://www.ammara.com/access_image_faq/recursive_folder_search.html

Für dein Vorhaben könnte dies so aussehen
01.
Option Compare Text 
02.
 
03.
Sub deleteFiles() 
04.
    Dim FILEFILTER As String, fso As Object, colFiles As New Collection 
05.
    '========Variablen für Anpassung ======= 
06.
    'Ordner in dem die Dateien liegen 
07.
    Const STARTFOLDER = "C:\temp" 
08.
    'DateiFilter mit Regular Expressions 
09.
    FILEFILTER = "*test*.exe" 
10.
    'Auch Dateien in Unterordnern bearbeiten 
11.
    Const RECURSION = True 
12.
    '======================================= 
13.
    Set fso = CreateObject("Scripting.Filesystemobject") 
14.
 
15.
    'Suche Dateien rekursiv in einem Ordner und lese sie in die Collection ein 
16.
    SearchFiles colFiles, fso.GetFolder(STARTFOLDER), FILEFILTER, RECURSION 
17.
 
18.
    ' lösche jede Datei die auf den Filter gepasst hat 
19.
    For Each f In colFiles 
20.
        fso.DeleteFile f, True 
21.
        Debug.Print "Datei: '" & f & "' wurde gelöscht!" 
22.
    Next 
23.
End Sub 
24.
 
25.
Function SearchFiles(colFiles As Collection, ByVal strFldr As Object, ByVal strFilter As String, ByVal boolRecursion As Boolean) 
26.
    Dim file As Object 
27.
    For Each file In strFldr.files 
28.
        If file.Name Like strFilter Then 
29.
            colFiles.Add file.Path 
30.
        End If 
31.
    Next 
32.
    If boolRecursion Then 
33.
        For Each subFolder In strFldr.SubFolders 
34.
            SearchFiles colFiles, subFolder, strFilter, True 
35.
        Next 
36.
    End If 
37.
End Function
Hier eine alternative Variante bei der man mit Regular Expressions suchen kann:
01.
Dim FILEFILTER,fso,regex,filesDeleted,file 
02.
'========Variablen für Anpassung ======= 
03.
'Startsuchordner 
04.
Const STARTFOLDER = "C:\temp" 
05.
'DateiFilter mit Regular Expressions 
06.
FILEFILTER = "^Neues Textdokument.*\.txt" 
07.
'Auch Dateien in Unterordnern bearbeiten 
08.
Const RECURSION = True 
09.
'======================================= 
10.
Set fso = CreateObject("Scripting.Filesystemobject") 
11.
Set regex = CreateObject("vbscript.regexp") 
12.
regex.Pattern = FILEFILTER 
13.
regex.IgnoreCase= True 
14.
parseFolders fso.GetFolder(STARTFOLDER), RECURSION 
15.
 
16.
MsgBox "Folgende Dateien wurden gelöscht: " & filesDeleted 
17.
Set regex = Nothing 
18.
Set fso = Nothing 
19.
 
20.
Function parseFolders(strFldr,boolRecursion) 
21.
	For each file in strFldr.Files 
22.
		If regex.Test(file.Name) Then 
23.
			fso.DeleteFile file.Path, True 
24.
			filesDeleted = filesDeleted & file.Path & vbNewLine 
25.
		End If 
26.
	Next 
27.
	 
28.
	If boolRecursion Then 
29.
		For Each subFolder in strFldr.SubFolders 
30.
			parseFolders subFolder, True 
31.
		Next 
32.
	End If 
33.
End Function 
34.
 
Grüße Uwe
Bitte warten ..
Mitglied: 116301
05.06.2014 um 10:15 Uhr
Hallo Uwe!

Wobei man dann auch den Like-Operator mit 'Option Compare Text' verwenden könnte, der auch Wildcards erlaubt

Grüße Dieter
Bitte warten ..
Mitglied: colinardo
05.06.2014 um 10:16 Uhr
Yip, danke für die Ergänzung war zu sehr auf VBS fixiert

Grüße Uwe
Bitte warten ..
Mitglied: thomas1972
05.06.2014, aktualisiert um 12:33 Uhr
Hallo,

vielen dank für die Hilfestellung,
habe nur das Problem, das ich keine Rechte auf den C:\$Recycle.Bin habe und somit er auf einen Fehler Zugriff verweigert läuft.
Hab daher die Option On Error Resume Next eingebunden

Nun dauert es ewig bis er fertig ist,
Kann ich irgendwie den C:\$Recycle.Bin umgehen?
Bitte warten ..
Mitglied: colinardo
05.06.2014, aktualisiert um 14:36 Uhr
Wie bereits oben gesagt: die Prozedur ist eigentlich nicht dafür geeignet eine ganze Festplatte zu durchsuchen. Du solltest es auf ein paar Ordner einschränken, und für die jeweils einmal durchlaufen lassen.
Wie sich diese diversen Probleme die bei einer rekursiven Suche auftauchen können umgehen lassen habe ich hier mit einem C# Programm demonstriert:
http://www.administrator.de/contentid/235750

Vor allem wird die Suche im jetzigen Zustand bei Angabe eines ganzen Laufwerks ewig laufen, und vermutlich irgendwann bei sehr tief verschachtelten Ordnern die Rekursionstiefe überschreiten.

Es gibt noch eine Lösung über den indexdienst von Windows, aber dann müssen deine Files indiziert sein.

Eine zuverlässige Lösung via VBA müsste ich erst nochmal evaluieren. Ich persönlich würde mir die entsprechende Funktion via C# als COM-DLL kompilieren, die DLL in VBA einbinden und dann die Funktion aufrufen, aber das ist für dich vermutlich zu starker Tobak.

Grüße Uwe
Bitte warten ..
Ähnliche Inhalte
Datenbanken
ACCESS 2010 Datum über vba
gelöst Frage von CrashOverDatenbanken4 Kommentare

Hallo an Alle, ich habe da eine Frage, ich habe eine Access Datenbank einwickelt, und bin an einem Phänomen ...

VB for Applications
Access 2010 vba Recordset
gelöst Frage von EUuserVB for Applications3 Kommentare

Hallo zusammen, ich arbeite seit langem mal wieder mit Access und vba: Ich habe eine Datenbank, zwei Tabellen (identisch ...

Datenbanken
Syntaxfehler VBA Access 2010
gelöst Frage von Dr.CornwallisDatenbanken6 Kommentare

Liebe Gemeinde, ich habe (schon wieder) einen Fehler im Code und ich komm einfach nicht drauf warum es nicht ...

VB for Applications
VBA Code Änderung Access 2010
gelöst Frage von Dr.CornwallisVB for Applications6 Kommentare

Liebe Gemeinde, ein Kollege hat mir einmal einen VBA Code zur Ermittlung des 1. und 5. Arbeitstags eines Monats ...

Neue Wissensbeiträge
Windows 10

Autsch: Microsoft bündelt Windows 10 mit unsicherer Passwort-Manager-App

Tipp von kgborn vor 13 StundenWindows 102 Kommentare

Unter Microsofts Windows 10 haben Endbenutzer keine Kontrolle mehr, was Microsoft an Apps auf dem Betriebssystem installiert (die Windows ...

Sicherheits-Tools

Achtung: Sicherheitslücke im FortiClient VPN-Client

Tipp von kgborn vor 15 StundenSicherheits-Tools

Ich weiß nicht, wie häufig die NextGeneration Endpoint Protection-Lösung von Fortinet in deutschen Unternehmen eingesetzt wird. An dieser Stelle ...

Internet

USA: Die FCC schaff die Netzneutralität ab

Information von Frank vor 1 TagInternet3 Kommentare

Jetzt beschädigt US-Präsident Donald Trump auch noch das Internet. Der neu eingesetzte FCC-Chef Ajit Pai ist bekannter Gegner einer ...

DSL, VDSL

ALL-BM200VDSL2V - Neues VDSL-Modem mit Vectoring von Allnet

Information von Lochkartenstanzer vor 1 TagDSL, VDSL2 Kommentare

Moin, Falls jemand eine Alternative zu dem draytek sucht: Gruß lks

Heiß diskutierte Inhalte
TK-Netze & Geräte
VPN-fähige IP-Telefone
Frage von the-buccaneerTK-Netze & Geräte16 Kommentare

Hi! Weiss noch jemand ein VPN-fähiges IP-Telefon mit dem man z.B. einen Heimarbeitsplatz gesichert anbinden könnte? Habe nur einen ...

Windows Server
GPO nur für bestimmte Computer
Frage von Leo-leWindows Server13 Kommentare

Hallo Forum, gern würde ich ein Robocopy script per Bat an eine GPO hängen. Wichtig wäre aber dort der ...

Windows Server
KMS Facts for Client configuration
Frage von winlinWindows Server13 Kommentare

Hey Leute, wir haben in unserem Netz nun einen neuen KMS Server. Haben Bestands-VMs die noch nicht aktiviert sind. ...

Windows Tools
Software-Tool zum Entfernen von bösartigem Windows
Frage von emeriksWindows Tools11 Kommentare

Hi, siehe Betreff hat das jemals irgendjemand schonmal sinnvoll eingesetzt? (MRT) E.