Expectコマンドを使用しようとしていますが、コマンドの結果をGzipファイルにパイプするまで、すべてがうまく機能します。以下はbashファイルの一部です。
XYZ=$(expect -c "
spawn python log-connector.py -s $strt -e $end -i 600 -a https://server:9000 -u someaccount -f ./conf/firewall-fields2.txt -q ./conf/query.txt -z | gzip >> /data/sources/results-$strt2-$end2.json.gz
expect \"Password:\"
send \"$pass\r\"
interact
")
echo "$XYZ"
$start
- 変数(開始日)
$end
- 変数(終了日)
$strt2
- 変数(開始日は00:00)
$end2
- 変数(終了日は23:59)
$pass
- ユーザーが以前に入力したパスワードです。
削除したら
| gzip >> /data/sources/results-$strt2-$end2.json.gz
上から見ると期待通りに動作します。追加すると、次のエラーが発生します。
send: spawn id exp7 not open
while executing
usage: API [-h] [-s START] [-e END] [-d DAY] [-i INTERVAL]
[-a LOGGER] [-l LOGFILE] [-f FIELDS] [-q QUERY]
[-o OUTPUT] [-t FORMAT] [-u USER] [-p PASS] [-z]
API: error: unrecognized arguments: | gzip >> /data/sources/results-20180604-20180604.json.gz
ベストアンサー1
パイプとリダイレクトを解釈するためにシェルを使用することもできます。引用を簡単にするためにHeredocを使用します。
XYZ=$(expect <<END_EXPECT
set timeout -1
spawn sh -c {python log-connector.py -s $strt -e $end -i 600 -a https://server:9000 -u someaccount -f ./conf/firewall-fields2.txt -q ./conf/query.txt -z | gzip >> /data/sources/results-$strt2-$end2.json.gz}
expect "Password:"
send "$pass\r"
expect eof
END_EXPECT
)
echo "$XYZ"