3 回答

TA貢獻1845條經驗 獲得超8個贊
嘗試將stderr重定向到stdout并$()用于捕獲它。換一種說法:
VAR=$((your-command-including-redirect) 2>&1)
由于您的命令將stdout重定向到某個地方,因此它不應干擾stderr??赡苡幸环N更簡潔的編寫方法,但這應該可行。
編輯:
這確實有效。我已經測試過了:
#!/bin/bash
BLAH=$((
(
echo out >&1
echo err >&2
) 1>log
) 2>&1)
echo "BLAH=$BLAH"
將打印BLAH=err并且文件log包含out。

TA貢獻1772條經驗 獲得超8個贊
對于Bash中的任何通用命令,您可以執行以下操作:
{ error=$(command 2>&1 1>&$out); } {out}>&1
常規輸出正常出現,任何將stderr的內容都捕獲在$ error中(使用它保存換行符時將其引用為“ $ error”)。要將stdout捕獲到文件,只需在末尾添加重定向,例如:
{ error=$(ls /etc/passwd /etc/bad 2>&1 1>&$out); } {out}>&1 >output
分解它,從外面讀入它:
為整個塊創建文件描述$ out,復制stdout
在$ error中捕獲整個命令的標準輸出(但請參見下文)
該命令本身將stderr重定向到stdout(在上面捕獲),然后將stdout從塊外部重定向到原始stdout,因此僅捕獲stderr

TA貢獻1821條經驗 獲得超5個贊
您可以將stdout引用從重定向之前保存到另一個文件號(例如3)中,然后將stderr重定向到該文件:
result=$(mysqldump --user=$dbuser --password=$dbpswd \
--host=$host $mysqldb 3>&1 2>&3 | gzip > $filename)
因此3>&1會將文件編號3重定向到stdout(注意,這是在使用管道將stdout重定向之前)。然后2>&3將stderr重定向到3號文件,該文件現在與stdout相同。最后,將stdout通過饋入管道進行重定向,但這不會影響文件編號2和3(請注意,從gzip重定向stdout與mysqldump命令的輸出無關)。
編輯:更新了命令以從命令重定向stderr mysqldump而不是gzip,我的第一個答案太快了。
- 3 回答
- 0 關注
- 907 瀏覽
添加回答
舉報