tk, tcl exec stderr, stdout отдельно
Вопрос
У меня есть скрипт tcl.
Проблема в том, что мне нужно вызвать скрипт, который может что-то записать в stderr (это не критический сбой).
Я хотел бы захватить stderr и stdout отдельно в tk / tcl.
if { [catch {exec "./script.sh" << $data } result] } {
puts "$::errorInfo"
}
Этот код вернет мой результат, но он также содержит stderr.
Также я хотел бы получить результат в переменной.
Заранее спасибо ...
Решение
Если вы откроете команду как канал вместо использования exec
, вы можете разделить stdout и stderr. См. http://wiki.tcl.tk/close
set data {here is some data}
set command {sh -c {
echo "to stdout"
read line
echo "$line"
echo >&2 "to stderr"
exit 42
}}
set pipe [open "| $command" w+]
puts $pipe $data
flush $pipe
set standard_output [read -nonewline $pipe]
set exit_status 0
if {[catch {close $pipe} standard_error] != 0} {
global errorCode
if {"CHILDSTATUS" == [lindex $errorCode 0]} {
set exit_status [lindex $errorCode 2]
}
}
puts "exit status is $exit_status"
puts "captured standard output: {$standard_output}"
puts "captured standard error: {$standard_error}"
Другие советы
Используйте 2 > перенаправить stderr:
if { [catch {exec "./script.sh" << $data 2> error.txt} result } {
puts "$::errorInfo"
}
Затем вы можете прочитать содержимое файла error.txt:
package require Tclx; # Needed for the read_file command
set err [read_file error.txt]
puts "s1: err = $err"
Не связан с StackOverflow