Batch für DS von Daten mit fortlaufender Nummer
Hallo,
folgende annahme:
im verzeichnis c:\test liegen jede menge edi dateien mit dem namen import_fortlaufendernummer.edi mit dem erstellungsdatum als sortierung.
diese sollen dann in jjjj\mm jeweils am ende vom monat weggemoved werden.
die verzeichnisanlegerei bekomme ich noch hin,
if exist c:\test\*.dat FOR /F "usebackq eol=; tokens=2,3,4* delims=. " %%i in (`Date /T`) do if not exist .\%%k mkdir .\%%k
if exist c:\test\*.dat FOR /F "usebackq eol=; tokens=2,3,4* delims=. " %%i in (`Date /T`) do if not exist %%k\%%j mkdir %%k\%%j
leider hängt es bei mir momentan an der erkennung vom datum für die entsprechenden dateien.
in dem verzeichnis sind pro monat ca 30000 dateien, und jedesmal wenn ich was suchen möchte, braucht der eine ewigkeit bis der mal
das verzeichnis anzeigt. deswegen die aufräumaktion.
wäre super wenn jemand mir da weiterhelfen könnte.
folgende annahme:
im verzeichnis c:\test liegen jede menge edi dateien mit dem namen import_fortlaufendernummer.edi mit dem erstellungsdatum als sortierung.
diese sollen dann in jjjj\mm jeweils am ende vom monat weggemoved werden.
die verzeichnisanlegerei bekomme ich noch hin,
if exist c:\test\*.dat FOR /F "usebackq eol=; tokens=2,3,4* delims=. " %%i in (`Date /T`) do if not exist .\%%k mkdir .\%%k
if exist c:\test\*.dat FOR /F "usebackq eol=; tokens=2,3,4* delims=. " %%i in (`Date /T`) do if not exist %%k\%%j mkdir %%k\%%j
leider hängt es bei mir momentan an der erkennung vom datum für die entsprechenden dateien.
in dem verzeichnis sind pro monat ca 30000 dateien, und jedesmal wenn ich was suchen möchte, braucht der eine ewigkeit bis der mal
das verzeichnis anzeigt. deswegen die aufräumaktion.
wäre super wenn jemand mir da weiterhelfen könnte.
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 78285
Url: https://administrator.de/forum/batch-fuer-ds-von-daten-mit-fortlaufender-nummer-78285.html
Ausgedruckt am: 24.12.2024 um 13:12 Uhr
7 Kommentare
Neuester Kommentar
Hallo minicoop!
Versuch es mal so:
Das "echo" vor dem "move" sorgt dafür, dass der Verschiebebefehl (zum Testen) nur angezeigt, aber nicht ausgeführt wird.
Zum Erstellen der Ordner noch ein Hinweis: Es genügt eigentlich
da der "Jahresordner" dabei automatisch erstellt wird.
Grüße
bastla
[Edit] Unter W2000 wird die Jahreszahl (%%b) nur zweistellig ausgegeben und muss daher durch ein vorangestelltes 20 ergänzt werden. [/Edit]
Versuch es mal so:
for %%i in (C:\Test\import_*.edi) do for /f "tokens=2,3* delims=. " %%a in ("%%~ti") do echo move %%i %%b\%%a\
Zum Erstellen der Ordner noch ein Hinweis: Es genügt eigentlich
if exist c:\test\*.dat FOR /F "tokens=2,3,4* delims=. " %%i in (`Date /T`) do if not exist %%k\%%j md %%k\%%j
Grüße
bastla
[Edit] Unter W2000 wird die Jahreszahl (%%b) nur zweistellig ausgegeben und muss daher durch ein vorangestelltes 20 ergänzt werden. [/Edit]
Moin Nedim,
Allerdings wird es dann mit Batch-Mitteln etwas hakelig (wie man/frau in Bremen so sacht), weil die CMD.exe nicht mit Datumswerten (Datumsdifferenzen) "rechnen kann.
Deshalb
a) prüfen, ob auch einmal im Monat statt einmal pro Woche für diesen Batchjob akzeptabel wäre. Denn die Vergleichsmöglichkeiten mit "Monat" und "Jahr" hast Du ja/nutzt Du ja bereits.
b) kannst Du natürlich noch eine Datum-älter-als-Prüfung einbauen über einen VBS-Skript-Aufruf.
Dazu findest Du wie geschrieben eine Menge Beispiele hier im Forum (Suchfunktion "Dateien älter als")
c) Drittens könntest Du auch von einem schnelleren Utility (z.B. mit "XCopy /L") eine Liste aller Dateien älter als whatever erzuegen lassen und diese abarbeiten statt den kompletten Verzeichnisinhalt.
Bitte stöbere erst versuchsweise hier in den vorhandenen Lösungen - solltest Du dort nichts finden, dann melde Dich nochmals hier.
Grüße
Biber
kann man theoretisch hier auch hingehen und sagen alles was älter ist wie eine woche soll er in die entsprechenden ordner verschieben ?
Ja, theoretisch schon... haben wir hier im Forum auch schon ein paarmal gemacht.Allerdings wird es dann mit Batch-Mitteln etwas hakelig (wie man/frau in Bremen so sacht), weil die CMD.exe nicht mit Datumswerten (Datumsdifferenzen) "rechnen kann.
Deshalb
a) prüfen, ob auch einmal im Monat statt einmal pro Woche für diesen Batchjob akzeptabel wäre. Denn die Vergleichsmöglichkeiten mit "Monat" und "Jahr" hast Du ja/nutzt Du ja bereits.
b) kannst Du natürlich noch eine Datum-älter-als-Prüfung einbauen über einen VBS-Skript-Aufruf.
Dazu findest Du wie geschrieben eine Menge Beispiele hier im Forum (Suchfunktion "Dateien älter als")
c) Drittens könntest Du auch von einem schnelleren Utility (z.B. mit "XCopy /L") eine Liste aller Dateien älter als whatever erzuegen lassen und diese abarbeiten statt den kompletten Verzeichnisinhalt.
Bitte stöbere erst versuchsweise hier in den vorhandenen Lösungen - solltest Du dort nichts finden, dann melde Dich nochmals hier.
Grüße
Biber
Hallo minicoop!
Scheint so, als wären die Hochkommata in `Date /T`auf "typographisch" geändert worden - eigentlich sollten sie so
aussehen ... (Das war jetzt die kürzeste Code-Zeile, die ich hier je gepostet habe. )
Noch als Nachtrag:
Grüße
bastla
Scheint so, als wären die Hochkommata in `Date /T`auf "typographisch" geändert worden - eigentlich sollten sie so
'
Noch als Nachtrag:
aber woher holt dieser das datum herbei? %%~ti ?
Infos zu "~t" (und ein paar anderen Möglichkeiten) findest Du gegen Ende der Hilfe zu "for" (for /?)Grüße
bastla