Gid*_*ina 5 bash pipe io-redirection shell-script
需要使用yad显示命令过程(通常是更新) ,同时将所有输出记录到给定的日志文件设置中。这就是我所拥有的
apt-get update | yad --width=400 --height=300 \
--title="Updating debian package list ..." --progress \
--pulsate --text="Updating debian package list ..." \
--auto-kill --auto-close \
--percentage=10
Run Code Online (Sandbox Code Playgroud)
上面的命令为进程创建一个脉动指示器并在完成时关闭,但我需要让它记录我尝试过的所有输出
apt-get update >>${logfile} 2>&1 | yad --width=400 --height=300 \
--title="Updating debian package list ..." --progress \
--pulsate --text="Updating debian package list ..." \
--auto-kill --auto-close \
--percentage=10
Run Code Online (Sandbox Code Playgroud)
但这给了我一个错误,并且在没有对话框和没有日志记录的情况下挂起,只是冻结。这是错误
GLib-CRITICAL **: g_source_remove: assertion `tag > 0' failed
Run Code Online (Sandbox Code Playgroud)
感谢帮助
该错误是因为您将所有输出重定向到$logfile
,因此没有要yad
处理的输出。您正在寻找的工具是tee
:
NAME
tee - read from standard input and write to standard output and files
SYNOPSIS
tee [OPTION]... [FILE]...
DESCRIPTION
Copy standard input to each FILE, and also to standard output.
Run Code Online (Sandbox Code Playgroud)
所以,你可以这样做:
apt-get update 2>&1 | tee -a ${logfile} |
yad --width=400 --height=300 \
--title="Updating debian package list ..." --progress \
--pulsate --text="Updating debian package list ..." \
--auto-kill --auto-close \
--percentage=10
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
3695 次 |
最近记录: |