BATCH - Ausgabe in zwei Dateien gleichzeitig
Hallo,
ganz simples Problem, knifflige Lösung ?
Ich habe ein längeres Skript, in dem ich diverse Aktionen ausführe, teilweise ergeben sich daraus so genannte "Statusmeldungen", jedoch immer "Log-Meldungen".
Beispiel:
SET STATUS=TEST.TXT
SET LOG=TEST.LOG
ECHO Skript startet...>%STATUS%
ECHO Skript startet...>%LOG%
DIR /w >>%LOG%
ECHO Skript beendet.>>%STATUS%
ECHO Skript beendet.>>%LOG%
Jetzt sind ja jeweils die ECHO Zeilen gleich, kann man das nicht zusammenfassen ?
Meine Idee wäre dahingehend:
ECHO Skript startet...>>%STATUS% >>&%LOG%
Klappt aber nicht - und ich weiß nicht warum
ganz simples Problem, knifflige Lösung ?
Ich habe ein längeres Skript, in dem ich diverse Aktionen ausführe, teilweise ergeben sich daraus so genannte "Statusmeldungen", jedoch immer "Log-Meldungen".
Beispiel:
SET STATUS=TEST.TXT
SET LOG=TEST.LOG
ECHO Skript startet...>%STATUS%
ECHO Skript startet...>%LOG%
DIR /w >>%LOG%
ECHO Skript beendet.>>%STATUS%
ECHO Skript beendet.>>%LOG%
Jetzt sind ja jeweils die ECHO Zeilen gleich, kann man das nicht zusammenfassen ?
Meine Idee wäre dahingehend:
ECHO Skript startet...>>%STATUS% >>&%LOG%
Klappt aber nicht - und ich weiß nicht warum
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 192896
Url: https://administrator.de/contentid/192896
Ausgedruckt am: 21.11.2024 um 22:11 Uhr
9 Kommentare
Neuester Kommentar
Stichworte: 'UnxUtils' und weiter führend 'tee.exe'
MfG, FM_81
moin,
Du kannst einVerbratenes Hänchen Äähm Verwendetes Handle in dem gleichen Befehl nicht nochmal an etwas Umleiten oder Dublizieren.
Deine Datei Status wird immer leer bleiben.
Das wäre ja einfach
Ich plädiere dazu, bei einem sehr Langen Batch am Anfang eine Variable zu setzen:
Das ist ein guter Kompromiss zwischen Schreibkram; Performance und Batchlänge.
Gruß Phil
ECHO Hallo >%STATUS% >>%LOG%
Das geht so gar nicht!Du kannst ein
Deine Datei Status wird immer leer bleiben.
Das wäre ja einfach
echo Testen obs nicht geht. >datei
echo Hallo >datei >con
type Datei
Zumal es dafür etliche Würgarounds gibt. (siehe Tee)echo Hallo >datei >con
type Datei
Ich plädiere dazu, bei einem sehr Langen Batch am Anfang eine Variable zu setzen:
set X= 1^>tmp.t ^&^&type tmp.t ^>^>status ^&^&type tmp.t ^>^>log ^&^&type tmp.t
echo Hallo test.%X%
Das ist ein guter Kompromiss zwischen Schreibkram; Performance und Batchlänge.
Gruß Phil
moin yakazaa,
hast Du noch keine Möglichkeit gefunden eine Variante von den vieln Angebotenen zu nutzen?
Wenn Du unbedingt mehrere Umleitungen in mehrere Dateien haben möchtest, dann eventuell so:
Durch die Komplizierte Schreibweise der Umleitung ist die Handhabung nicht so einfach, und die Umleitung dauert auch sehr lange.
Da diese Teesorten immer erst die Ausgabe geben, wenn der erste Befehl der Kette durch ist, ist es mit der Temporären Datei immer noch am Schnellsten.
Diese auf die Handles umzubiegen geht so:
Setz doch bitte den Betrag auf gelöst. Danke
Gruß Phil
hast Du noch keine Möglichkeit gefunden eine Variante von den vieln Angebotenen zu nutzen?
Wenn Du unbedingt mehrere Umleitungen in mehrere Dateien haben möchtest, dann eventuell so:
@set prompt=$g$s
setlocal
rem Diese Variable(n) Dubliziert(en) eine Ausgabe in Handle 1; und Handle 3-9
rem Handle 1 wird immer ausgegeben.
rem Handle 3-9 kann bei Bedarf in eine Datei Umgeleitet werden,
rem diese werden jedoch nicht extra ausgegeben.
rem Hanlde 3 kann Aber immer Ausgegeben werden.
set X1+3=^|@for /f "delims=" %%_ in ('findstr /n "^" ') do @set "line=%%_" ^&for %%: in ("@" ">&3") do @cmd /von /c "(%%~: echo(!Line:*:=!)"
set X13=^|@for /f "delims=" %%_ in ('findstr /n "^" ') do @set "line=%%_" ^&for %%: in ("@" ">&3 3>nul") do @for /f "tokens=1,2" %%# in ("%%~:") do @cmd /von /c "%%$ (%%# echo(!Line:*:=!)"
set X1345=^|for /f "delims=" %%_ in ('findstr /n "^" ') do @set "line=%%_" ^&for %%: in ("@" ">&3 3>nul" ">&4 4>nul" ">&5 5>nul") do @for /f "tokens=1,2" %%# in ("%%~:") do @cmd /von /c "(%%# echo(!Line:*:=!) %%$"
set X1-9=^|for /f "delims=" %%_ in ('findstr /n "^" ') do @set "line=%%_" ^&for %%: in ("@" ">&3 3>nul" ">&4 4>nul" ">&5 5>nul" ">&6 6>nul" ">&7 7>nul" ">&8 8>nul" ">&9 9>nul") do @for /f "tokens=1,2" %%# in ("%%~:") do @cmd /von /c "(%%# echo(!Line:*:=!) %%$"
rem Dateien loeschen
del Datei?
echo on
rem echo Test doppelt Handle 1+3%X1+3%
@echo off
echo Test doppelt Handle 1 ^^^& 3%X1+3%
echo Test Handle 1-5 ^(3-5^) stumm%X1345%
rem Schreibarbeit ist es dafür Trotz alledem
echo Test Handle 1-9 ^(3-9^) stumm, 7in Datei7%X1-9% 7^^^>^^^>Datei7
echo Handling Handle Test 1 3%x13% 1^^^>^^^>Datei1 3^^^>^^^>Datei3
echo Handling Handle Test 1+3%X1+3% 1^^^>^^^>Datei1 3^^^>^^^>Datei3
echo Test Handle 1 3-5%x1345% 3^^^>^^^>Datei3 4^^^>^^^>Datei4 5^^^>^^^>Datei5
echo ------
find /n /v "" Datei?
echo on
rem dir %X13% 3^^^>^^^> Ausgabe.txt
@echo off
echo Leite Handle 3 in Ausgabe.txt
del Ausgabe.txt xcopy.log
dir %X13% 3^^^>^^^> Ausgabe.txt
echo on
rem xcopy 2>&1 %X1+3% ^^^>^^^>xcopy.log
@echo off
echo Leite Handle 1 in Log
xcopy 2>&1 %X1+3% ^^^>^^^>xcopy.log
echo ------
type Ausgabe.txt xcopy.log
pause
Da diese Teesorten immer erst die Ausgabe geben, wenn der erste Befehl der Kette durch ist, ist es mit der Temporären Datei immer noch am Schnellsten.
Diese auf die Handles umzubiegen geht so:
@set prompt=$g$s
setlocal
set Tee=^|(findstr "^" ^>"%temp%\tee.txt" ^&type "%temp%\tee.txt" ^&type "%temp%\tee.txt" ^>^&3)
set TEE8=^|3^>nul 4^>nul 5^>nul 6^>nul 7^>nul 8^>nul 9^>nul (findstr "^" ^>"%temp%\tee.txt" ^&type "%temp%\tee.txt" ^&type "%temp%\tee.txt" ^>^&3 ^&type "%temp%\tee.txt" ^>^&4 ^&type "%temp%\tee.txt" ^>^&5 ^&type "%temp%\tee.txt" ^>^&6 ^&type "%temp%\tee.txt" ^>^&7 ^&type "%temp%\tee.txt" ^>^&8 ^&type "%temp%\tee.txt" ^>^&9)
rem echo Test doppelt Handle 1+3%Tee%
@echo off
echo Test doppelt Handle 1 ^& 3%Tee%
echo on
rem dir %tee% 3> Ausgabe.txt
@echo off
echo Leite Handle 3 in Ausgabe.txt
dir %tee% 3> Ausgabe.txt
echo on
rem xcopy 2>&1 %tee% >xcopy.log
@echo off
echo Leite Handle 1 in Log
xcopy 2>&1 %tee% >xcopy.log
echo ------
type Ausgabe.txt xcopy.log
pause
rem die Beiden Variablen TEE TEE8 / Anweisungen stehen nun in der CMD-Line zur Verfügung
cmd /k prompt $g$S
Gruß Phil