Einzelnen Beitrag anzeigen

Benutzerbild von himitsu
himitsu

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

AW: BAT/CMD > Umleitung der Ausgabe

  Alt 5. Apr 2012, 11: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.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

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