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
GELÖST

Per Batch Recursive nach Log-files des heutigen Datums suchen und diese in einen Ordner kopieren

Frage Entwicklung Batch & Shell

Mitglied: Xziped

Xziped (Level 1) - Jetzt verbinden

11.03.2009, aktualisiert 13:53 Uhr, 6514 Aufrufe, 7 Kommentare

Liebe Community

Ich würde gerne mit einem Batch-Script den Ordner d:\data0 inklusive aller Unterordner nach *.log dateien durchsuchen.
Falls die gefundenen *.log dateien am heutigen Tag verändert/angelegt wurden, sollten diese in den Ordner d:\data0\logs gespeichert werden.

Da ich mich mit Batch-Scripting nicht wirklich auskenne, bitte ich um Lösungsansätze.

Derzeit habe ich das Script wie folgt umgesetzt :

Habe mal manuell geschaut in welchen Ordnern Logdateien vorhanden sind und habe die Pfade als Quelle1 - Quelle73 definiert.
Als Ziel habe ich nur eines angegeben d:\data0\logs. Das Script durchforstet also eine Quelle nach der anderen und überprüft das Datum
und kopiert die heutigen Logs in den Zielordner.

Da dieses Script nun auf diverse Server verteilt werden soll und dort die Pfade nicht umbedingt ident sind,
bedeutet dies für mich einen ordentlichen Mehraufwand, den man sich mit einem Script eventuell Sparen könnte.

Vielen Dank
liebe Grüße
Xziped
Mitglied: bastla
11.03.2009 um 16:18 Uhr
Hallo Xziped und willkommen im Forum!

Wie immer in solchen "Datei-Sammel-Situationen" stellt sich die Frage, ob es gleichnamige .log-Files in verschiedenen Ordnern gibt, da dann natürlich die später in den Sammel-Ordner kopierten / verschobenen Dateien die bereits darin befindlichen überschreiben ...

Falls alle Dateien unterschiedliche Namen haben sollten, könnte der Batch etwa so aussehen:
01.
@echo off & setlocal 
02.
set "Basis=D:\data0" 
03.
set "Ziel=%Basis%\logs" 
04.
set "Typ=log" 
05.
 
06.
if not exist "%Ziel%" md "%Ziel%" 
07.
 
08.
REM Dateien aus Basisordner einsammeln 
09.
for /f "delims=" %%f in ('dir /b "%Basis%\*.%Typ%" 2^>nul') do call :ProcessFile "%Basis%\%%f" 
10.
REM Dateien aus den Unterordnern (rekursiv) einsammeln ... 
11.
for /d %%d in ("%Basis%\*.*") do ( 
12.
    REM ... dabei aber den Zielordner aussparen 
13.
    if /i "%%d" neq "%Ziel%" ( 
14.
        for /f "delims=" %%f in ('dir /s /b "%%d\*.%Typ%" 2^>nul') do call :ProcessFile "%%f" 
15.
16.
17.
goto :eof 
18.
 
19.
:ProcessFile 
20.
echo %~t1|findstr /b "%date%">nul && ( 
21.
    echo %~1 
22.
    copy %1 "%Ziel%">nul 
23.
24.
goto :eof
Grüße
bastla

[Edit] Fehlendes Anführungszeichen in Zeile 3, Unterdrückung der "dir"-Fehlermeldungen und Schalter "/i" bei "if" ergänzt [/Edit]
Bitte warten ..
Mitglied: Xziped
11.03.2009 um 17:23 Uhr
Wow Vielen Dank für die rasche Beantwortung.
Werde ich sofort ausprobieren und Bescheid geben ob es funktioniert hat.

lg Xziped
Bitte warten ..
Mitglied: Xziped
11.03.2009 um 17:59 Uhr
Hallo bastla

Vielen Dank für deine Hilfe.

Ich habe bei deinem Script in der dritten Zeile hinter set "Ziel=%Basis%\logs noch ein " gesetzt.

Leider bekomme ich bei Aufruf vom Script nur folgende Fehlermeldung :



Datei nicht gefunden
".log" kann syntaktisch an dieser Stelle nicht verarbeitet werden.



Er erstellt mir zwar den Ordner d:\data0\logs aber ohne Inhalt.
Hast du vielleicht eine Ahnung woran das liegen könnte?

liebe Grüße Xziped
Bitte warten ..
Mitglied: bastla
11.03.2009 um 18:55 Uhr
Hallo Xziped!
Ich habe bei deinem Script in der dritten Zeile hinter set "Ziel=%Basis%\logs noch ein " gesetzt.
Hatte ich leider vergessen - ist aber inzwischen auch oben ergänzt.

Die Meldung "Datei nicht gefunden" hat als wahrscheinlichste Ursache, dass es in "D:\data0" keine .log-Datei gibt - sollte zwar den weiteren Ablauf nicht stören, ist aber dennoch unschön und daher ebenfalls oben korrigiert (wie auch eine weitere Ungenauigkeit) - daher bitte mit der jetzt aktuellen Version testen.

Um der Meldung
".log" kann syntaktisch an dieser Stelle nicht verarbeitet werden.
auf die Spur zu kommen, könntest Du das "echo off" auf "echo on" ändern und den Batch von der Kommandozeile aus starten - es wird dann jeder Befehl vor der Ausführung zunächst angezeigt, wobei die Variablen durch ihre aktuellen Werte ersetzt werden.

Die "REM"-Zeilen kannst Du übrigens bedenkenlos aus dem Batch entfernen ...

Grüße
bastla
Bitte warten ..
Mitglied: Xziped
11.03.2009 um 19:17 Uhr
Das Script funktioniert plötzlich ganz ohne Fehler und tut genau das was es soll

Lieber bastla Vielen Dank für deine Hilfe.
Bitte warten ..
Mitglied: bastla
11.03.2009 um 19:23 Uhr
Hallo Xziped!
Das Script funktioniert plötzlich ganz ohne Fehler und tut genau das was es soll
Damit kann ich leben ...

Nur zur Sicherheit möchte ich nochmals auf das Thema "Überschreiben durch gleichnamige Dateien aus anderen Ordnern" hinweisen ...

Grüße
bastla
Bitte warten ..
Mitglied: Xziped
12.03.2009 um 10:01 Uhr
Ich habe dies überprüft und in meinem Fall kann es zum Glück nicht vorkommen, dass die Log-Files den selben Namen haben.

Grüße Xziped
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
Ordner Umbenennen +heutiges Datum
gelöst Frage von ahsendenBatch & Shell12 Kommentare

Hallo zusammen, Ich muss für eine tagliche Außerhaussicherrung auf Externe Festplatten immer folgendes manuell ausführen: Löschen des Ordners "Backup-extern_20170201" ...

Linux
Suche Mailserver Auth Log File
Frage von mexxLinux12 Kommentare

Hallo, Ich betreibe einen eigenen Mailserver (postfix) und suche die Logfile in der man die erfolgreichen und fehlgeschlagenen Logins ...

Batch & Shell
Files in Ordner kopieren
Frage von 123182Batch & Shell14 Kommentare

Hallo, Ich habe z.b. 100 Ordner (die einem einem Ordner mit variabler Position liegen - ich nenne ihn mal ...

Batch & Shell
Batch aktuellsten Ordner kopieren
gelöst Frage von MmarKussBatch & Shell2 Kommentare

Hallo @ all Problembeschreibung Ich habe einen Ordner, in welchem alle Daten in ojektbezogenen Unterordnern abgespeichert sind. (D:\Data_all ) ...

Neue Wissensbeiträge
Windows 10

Windows 10 Fall Creators Update - Neue Funktion Hyper-V Standardswitch kann ggf. Fehler bei Proxy Configs verursachen

Erfahrungsbericht von rzlbrnft vor 5 StundenWindows 101 Kommentar

Hallo Kollegen, Da wir die Gefahr lieben, haben wir bei einigen Usern nun mittlerweile das Creators Update drauf. Einige ...

Sicherheit

TLS-Zertifikat und privater Schlüssel von Microsofts Dynamics 365 geleakt

Information von Penny.Cilin vor 7 StundenSicherheit

Microsoft hat versehentlich das TLS-Zertifikat inklusive dem privaten Schlüssel seiner Business-Anwendung Dynamics 365 geleakt. TLS-Zertifikat und privater Schlüssel von ...

Viren und Trojaner

Deaktivierter Keylogger in HP Notebooks entdeckt

Information von bitcoin vor 1 TagViren und Trojaner2 Kommentare

Ein Grund mehr warum man Vorinstallationen der Hersteller immer blank bügeln sollte Der deaktivierte Keylogger findet sich im vorinstallierten ...

Router & Routing

Lets Encrypt kommt auf die FritzBox

Information von bitcoin vor 1 TagRouter & Routing

In der neuesten Labor-Version der FB7490 integriert AVM unter anderem einen Let's Encrypt Client für Zugriffe auf das Webinterface ...

Heiß diskutierte Inhalte
Netzwerkmanagement
Firefox Profieles im Roaming
gelöst Frage von Hendrik2586Netzwerkmanagement17 Kommentare

Hallo liebe Leute. :) Ich hab da ein kleines Problem, welches anscheinend nicht unbekannt ist. Wir nutzen hier in ...

LAN, WAN, Wireless
Brainstorming, einfachste Option 1 getrenntes LAN (mit WAN zugang)
Frage von 132954LAN, WAN, Wireless13 Kommentare

Hi, folgendes: Wir bekommen eine Glasfaser Leitung, Und das sollte Optional so aussehen: Ein Modem/Router für das WAN, ein ...

Batch & Shell
Trusted Sites für alle User auf dem PC einpflegen
Frage von xXTaKuZaXxBatch & Shell12 Kommentare

Aufgabestellung: Es sollen auf 1 PC (bzw. mehreren PCs) vertrauenswürdige Sites per Powershell eingetragen werden, die für alle User ...

Netzwerkgrundlagen
Hi eine blöde frage. xD
Frage von 132954Netzwerkgrundlagen12 Kommentare

Also: Habe 2012 r2 essentials neuinstalliert, allerdings installiert diese version ja gleich diesen gangen AD kram mit, den hab ...