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 Batch: wie mehrzeilige log.xml schreiben und Umfang auf einen Monat begrenzen?

Mitglied: maccoX

maccoX (Level 1) - Jetzt verbinden

22.01.2014, aktualisiert 23.01.2014, 1703 Aufrufe, 9 Kommentare, 2 Danke

Hallo,

ich möchte mit einer Batch Datei eine Log.xml schreiben, welche aber immer nur die letzten 31 Tage beinhaltet und nicht immer weiter wächst.

Jedes mal wenn ich die Batch Datei starte soll diese beim passenden Datum einfach nur die aktuelle Uhrzeit eintragen. Pro Tag kann die Batch aber öfters gestartet werden, sprich die Batch muss für den Tag dann eine zweite, dritte usw. Uhrzeit eintragen ohne die alten Tageswerte zu löschen.

Die xml Tags lassen sich ja gut schreiben mit z.B:
echo ^<tag1^>%uhrzeiten%^</tag1^> >> %log%

Wie man Uhrzeit und Datum an sich abfragt ist mir bekannt. Aber wie mache ich es, das ich verschiedene Tage habe, die ältesten automatisch wegfallen und pro Tag unterschiedlich viele Uhrzeitseinträge sind?


Ich hab mir als erste Überlegung gedacht, der Textdatei/xml 31 Zeilen zu spendieren und je nach dem welcher Tag ist (1-31) schreibt die Batch in die entsprechende Zeile (falls das möglich ist). Bloß wenn ich diese frisch schreibe verliere ich ja die alten Inhalte Am Besten wär ich könnte die neue Zeit einfach hinten an die Zeile dran hängen aber das geht ja schon allein deshalb nicht, weil der XML Schlusstag dann dazwischen ist.


Wie kann ich das am besten lösen?


Gruß, maccoX
Mitglied: pieh-ejdsch
22.01.2014 um 11:15 Uhr
moin maccoX,

Eine Logdatei wird fortwährend geschrieben - immer unten dran. Bei einem dazwischen herumschreiben muss immer eine Datei komplett neu geschrieben werden.
Eine Alternative wäre für jeden Tag eine Log zu erstellen. Dateiname 1 -31 oder besser "%Datum%" - Dateien älter als 31 Tage lassen sich mit forfiles oder robocopy löschen.

Die Erstellung der XML sollte immer nach Aktualisierung von einem LOG erfolgen. Mit dir die LOG Dateien nach Alter sortieren lassen und die Inhalte in die XML eintragen.

Gruß Phil
Bitte warten ..
Mitglied: Endoro
22.01.2014, aktualisiert um 14:06 Uhr
Hey,

ich hab das so verstanden, dass es keine LOG Dateien gibt sondern die XML das Log ist.
@maccoX kannst du das deutlicher erklären?
Gruss.
Bitte warten ..
Mitglied: maccoX
22.01.2014 um 14:20 Uhr
Danke euch Zwei!

Ja, es gibt keine LOG, die bat erstellt die log Datei die im xml Format ist und eben nicht zu groß werden soll.

Für jeden Tag eine eigene LOG Datei schreiben wär zu aufwendig bei nachträglicher Einsicht und zu viel Dateimüll, es soll schon alles in eine Datei. So viel ist es ja auch nicht.


Ich versuch es nochmal zu erklären was die Anforderungen sind:
Ich brauche eine Batch Datei die mir allein durch den Aufruf (mehrmals täglich) eine kleine log Datei im xml Format schreibt (log.xml) - was ja nichts anderes als eine Textdatei mit xml Tags ist (<tag>inhalt</tag>).

Darin muss die Batch das Datum notieren (Tag, und eventuell Monat langt) und für jeden Tag die Uhrzeit vom Aufruf der Batch Datei. Sprich am 22.1. starte ich die Batch um 9 Uhr, 15 Uhr und 20 Uhr, dann brauche ich genau diese Daten in der Batch. Für den nächsten Tag das gleiche Spiel usw. Blos sollen nicht irgendwann ewig viele Tage mit den Uhrzeiten drin stehen sondern es soll am Besten auf 31 Tage begrenzt sein.

Struktur der erstellten xml Datei sollte dann so ähnlich aussehen:

<log>
<0122>0900, 1500, 2000</0122>
<0121>1000, 1500, 1626, 1710</0121>
<0120>0900, 1900</0120>
</log>

wobei die Reihenfolge der Sortierung egal ist, das ist nur ein Beispiel wie es aussehen könnte!

Ich hoffe jetzt ist es klarer!

Gruß, maccoX
Bitte warten ..
Mitglied: Endoro
LÖSUNG 22.01.2014, aktualisiert 23.01.2014
Hey,

kannst du mal testen. Bei Datum und Zeit bin ich von normalem deutschen bzw. englischen Format ausgegangen.
01.
@echo off &setlocal disableDelayedExpansion
02.
set "LogFile=%UserProfile%\log.xml"
03.
set /a MaxEntries=31
04.

05.
if exist "%LogFile%" for /f "tokens=1,2 delims=<>" %%a in ('
06.
	findstr /br "<[0-9][0-9][0-9][0-9]" "%LogFile%"') do set "day.%%a=%%b"
07.
for /f "skip=%MaxEntries% delims==" %%a in ('set "day" 2^>nul^|sort /r') do set "%%a="
08.
for /f "tokens=1,2 delims=./" %%a in ("%date%") do set "today=%%b%%a"
09.
for /f "tokens=1,2 delims=:" %%a in ("%time%") do set "now=%%a%%b"
10.
set "now=%now: =0%"
11.
if defined day.%today% (call set "day.%today%=%%day.%today%%%, %now%") else set "day.%today%=%now%"
12.
(
13.
echo(^<log^>
14.
for /f "tokens=2* delims==." %%a in ('set "day"') do echo(^<%%a^>%%b^</%%a^>
15.
echo(^</log^>
16.
)>"%LogFile%"
Viele sagen, Batch sei zu primitiv für Arrays.

Gruss.
Bitte warten ..
Mitglied: maccoX
23.01.2014, aktualisiert um 11:07 Uhr
Hey Endoro,

vielen Dank - das ist ja perfekt!

Da kommt tatsächlich eine xml raus die genau so aussieht wie oben in meinem Beispiel
Funktioniert wunderbar, Datum- und Uhrzeitformat ist perfekt und es werden immer neue Uhrzeiten passend zum Tag eingetragen. Hab mein Datum am Computer auch 1, 2 mal verstellt und die Batch hat dann entsprechend Einträge für die neuen Tage erstellt, funktioniert also 1a! - aber das muss ich dir ja nicht sagen ;)

Nur das nach 31 Tagen nicht noch mehr Tage drin landen konnte ich so jetzt nicht testen aber da sonst alles top klappt vertrau ich dir da!

Vielen, vielen Dank, du hasts echt drauf!

Gruß, maccoX
Bitte warten ..
Mitglied: pieh-ejdsch
LÖSUNG 23.01.2014, aktualisiert um 16:50 Uhr
moin,

freu Dich auf Neujahr.

Zum Jahreswechsel benötigst Du noch die Jahreszahl sonst haut es Dir die Sortierung Durcheinander, der Dezember bleibt im Log stehen und zusätzlich steht noch das jüngste Datum in der XML drin - das geht so bis ende November. Der nächste Dezember würde dann wieder aktualisiert werden.
> (echo 0101&echo 0102&echo 1231&echo 1230)|sort/r
1231
1230
0102
0101
oder for Optionen anpassen sowie ^|findstr /n . noch in die erste Forschleife packen und nur bis Zeile 31 eindeutige Variablen setzen bzw gleich in einer Sub verarbeiten.

Gruß Phil
Bitte warten ..
Mitglied: Endoro
23.01.2014 um 12:55 Uhr
Hey Phil,

stimmt. Man könnte das Jahr mit in die XML übernehmen, an den Dateinamen anhängen und jeweils nach Silvester neu erstellen (log14.xml), intern mit Jahren rechnen (am besten) oder das Log mit gemischten 01/12-Monatsdaten löschen. Danke für den Hinweis.
Gruss.
Bitte warten ..
Mitglied: Endoro
LÖSUNG 23.01.2014, aktualisiert um 16:50 Uhr
Intern ordne ich jedem Datum aus dem Log eine Jahreszahl zum Sortieren zu. Alle Monatstage die grösser als %today% sind erhalten das vergangene, der Rest das aktuelle Jahr. Zur Ausgabe wird das Jahr "entfernt". Das gibt dann Probleme, wenn das Log so selten erstellt wird, dass ein Jahr "überrundet" wird.
01.
@echo off &setlocal disableDelayedExpansion
02.
set "LogFile=%UserProfile%\log.xml"
03.
set /a MaxEntries=31
04.

05.
for /f "tokens=1-3 delims=./" %%a in ("%date%") do set "today=%%b%%a"&set "year=%%c"
06.
for /f "tokens=1,2 delims=:" %%a in ("%time%") do set "now=%%a%%b"
07.
set "now=%now: =0%"
08.
set /a lastyear=year-1
09.

10.
if exist "%LogFile%" for /f "tokens=1,2 delims=<>" %%a in ('
11.
 findstr /br "<[0-9][0-9][0-9][0-9]" "%LogFile%"') do (
12.
	if "%%a" gtr "%today%" (set "day.%lastyear%.%%a=%%b") else set "day.%year%.%%a=%%b"
13.
)
14.
for /f "skip=%MaxEntries% delims==" %%a in ('set "day" 2^>nul^|sort /r') do set "%%a="
15.
if defined day.%year%.%today% (call set "day.%year%.%today%=%%day.%year%.%today%%%, %now%") else set "day.%year%.%today%=%now%"
16.
(
17.
echo(^<log^>
18.
for /f "tokens=3* delims==." %%a in ('set "day"') do echo(^<%%a^>%%b^</%%a^>
19.
echo(^</log^>
20.
)>"%LogFile%"
Assoziative Arrays sind flexibel.

Gruss.
Bitte warten ..
Mitglied: maccoX
23.01.2014 um 16:53 Uhr
Hey, danke!

Ein Jahr wird nicht übersprungen, somit ist die Lösung prima
Unglaublich was man mit Batch so alles machen kann!

Gruß, maccoX
Bitte warten ..
Ähnliche Inhalte
Server
Umfang von Windows Domänen
gelöst Frage von bugmenot2Server3 Kommentare

Guten Abend (Oder Guten Morgen, jenachdem :) ) Ich bin relativ neu was dies angeht und hätte eine Frage ...

Ausbildung

Umfang des Glossar bei der Projektdokumentation

gelöst Frage von AstratusAusbildung5 Kommentare

Moin, ich bin grade in den letzten Zügen meiner Dokumentation der betrieblichen Projektarbeit und erstelle zur Zeit das Glossar. ...

Windows Update

Jeden Monat Update Fehler 0x800705b4

Frage von geocastWindows Update1 Kommentar

Hallo Zusammen Ich habe folgendes Setup. Windows Server 2012R2 auf aktuellsten Stand, mit WSUS drauf (auch soweit alles aktuell). ...

Microsoft Office

Word Formel Monat -1

gelöst Frage von Florian86Microsoft Office3 Kommentare

Hallo, ich habe folgende Formel im Word 2016 { = ({ date \@ "MMMM" } -1) } jetzt bringt ...

Neue Wissensbeiträge
Windows Server
Windows Backup - FilterManager Event 3
Tipp von NixVerstehen vor 6 StundenWindows Server

Hallo zusammen, ich bin kein gelernter ITler und auch beruflich nicht in dem Feld tätig. Wir setzen in unserem ...

Windows 10

Windows 10 - Programme laufen schneller, wenn Sie mit Administratorrechten ausgeführt werden

Erfahrungsbericht von 1Werner1 vor 1 TagWindows 1011 Kommentare

Moin, das wollte ich erst nicht glauben, aber es ist so. Wenn Ihr ein Programm mit Administratorrechten unter Windows ...

Sicherheits-Tools
Putty hat heftige Bugs korrigiert!
Information von Lochkartenstanzer vor 2 TagenSicherheits-Tools8 Kommentare

Moin, Wie man aus herauslesen kann, sind in den Versionen vor 0.71 gravierende Bugs, die es angeraten erscheinen lassen, ...

Off Topic
Sachen die die Welt nicht braucht - Platz 1
Tipp von brammer vor 5 TagenOff Topic21 Kommentare

Hallo, ich habs als Tipp angelegt als Erfahrungsbericht nein Danke brammer

Heiß diskutierte Inhalte
Hardware
Telefonanlagen - Welche gibt es
Frage von Xaero1982Hardware34 Kommentare

Nabend Zusammen, ich suche eine neue TK Anlage und mein Auftraggeber will jetzt was völlig neues - State of ...

Outlook & Mail
Office 365 mit Email-Profil installieren
Frage von Carat2121Outlook & Mail18 Kommentare

Hallo, kurz zu meiner Person: Vor ungefahr 10 Jahren habe ich eine Umschuldung zum Fachinformatiker für Systemintegration gemacht aber ...

LAN, WAN, Wireless
Intel(R) PRO Wireless 3945ABG
gelöst Frage von Leon509LAN, WAN, Wireless15 Kommentare

Hallo, habe ein Laptop Fujitsu (Intel, 4GB, 2GHz, Windos10, Intel(R) PRO/Wireless 3945ABG ) ein O2 DSL Anschluss Home50. Leider ...

Microsoft Office
Excel Such- und Vergleichsfunktion
gelöst Frage von oesi1989Microsoft Office15 Kommentare

Hallo zusammen, ich habe 2 Tabellen mit Name, Vorname und Arbeitgeber. 1. Tabelle Name Vorname Geb-Datum Arbeitgeber Straße Ort ...