Einzelnen Beitrag anzeigen

Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.196 Beiträge
 
Delphi 12 Athens
 
#3

AW: BAT/CMD > Umleitung der Ausgabe

  Alt 5. Apr 2012, 10:10
BackUp.bat
Code:
RD /S /Q H:\BackUp\120330
DEL /Q H:\BackUp\120401\*09.sql
DEL /Q H:\BackUp\120401\*15.sql
E:\EXE\pg_dump --disable-triggers -i -f H:\BackUp\120404\ab2.18.sql -t ab2 --column-inserts -F p -a -h localhost -p 5432 -S xxx -U xxx xxx
E:\EXE\pg_dump --disable-triggers -i -f H:\BackUp\120404\ab2_param.18.sql -t ab2_param --column-inserts -F p -a -h localhost -p 5432 -S xxx -U xxx xxx
...
BackUpCall.bat
Code:
"E:\EXE\BackUp\BackUp.bat" > "E:\EXE\BackUp\BackUp.1204041827.Log"
Delphi-Quellcode:
ShellExecute(ParentWindow, nil, PChar('C:\Windows\System32\cmd.exe'),
  Pointer('/C "E:\EXE\BackUp\BackUp.bat" > "E:\EXE\BackUp\BackUp.1204041827.Log"'), PChar(ExtractFileDir(ParamStr(0))), SW_NORMAL);

//oder
ShellExecute(ParentWindow, nil, PChar('E:\EXE\BackUp\BackUpCall.bat'), nil, PChar(ExtractFileDir(ParamStr(0))), SW_NORMAL);

// oder über die Komandozeile (macht keinen Unterschied, ob ShellExecute oder so)
"E:\EXE\BackUp\BackUp.bat" > "E:\EXE\BackUp\BackUp.1204041827.Log"

// bzw.
"E:\EXE\BackUp\BackUpCall.bat"

Es landen jeweils nur die Befehle aus der BAT in der Log, aber Fehlermeldungen ala "Das System kann die angegebene Datei nicht finden." (DEL kann nichts löschen, da nichts mehr da ist) und die Meldungen der pg_dump.exe landen im CMD-Fenster.

[Edit]
DIR > C:\temp\Dir.txt wird umgeleitet, ebenso ein bei DIR , wenn die ausgabe der BAT umgeleitet wird,
aber scheinbar die "Fehlermeldungen" des RD und die Fehler-/Statusmeldungen der EXE nicht.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests

Geändert von himitsu ( 5. Apr 2012 um 10:15 Uhr)
  Mit Zitat antworten Zitat