キューに一連の保留中のジョブがあります。
$ atq
8 Mon Oct 29 13:21:00 2018
5 Mon Oct 29 10:36:00 2018
15 Mon Oct 29 13:31:00 2018
4 Mon Oct 29 10:35:00 2018
18 Mon Oct 29 15:55:00 2018
3 Mon Oct 29 10:31:00 2018
16 Mon Oct 29 15:54:00 2018
11 Mon Oct 29 13:24:00 2018
12 Mon Oct 29 13:24:00 2018
17 Mon Oct 29 15:53:00 2018
10 Mon Oct 29 13:23:00 2018
19 Tue Oct 30 15:43:00 2018
2 Mon Oct 29 07:41:00 2018
6 Mon Oct 29 10:41:00 2018
7 Mon Oct 29 13:20:00 2018
9 Mon Oct 29 13:22:00 2018
そして10月29日に該当作品を削除する予定です。幸いなことに、atrmは複数のジョブを削除できます。
atrm 8 5 15 4
それでも繰り返しがより良い解決策かもしれません。
$ atq | grep "Oct 29"
18 Mon Oct 29 15:55:00 2018
3 Mon Oct 29 10:31:00 2018
16 Mon Oct 29 15:54:00 2018
11 Mon Oct 29 13:24:00 2018
12 Mon Oct 29 13:24:00 2018
17 Mon Oct 29 15:53:00 2018
10 Mon Oct 29 13:23:00 2018
2 Mon Oct 29 07:41:00 2018
6 Mon Oct 29 10:41:00 2018
7 Mon Oct 29 13:20:00 2018
9 Mon Oct 29 13:22:00 2018
繰り返すためにジョブ番号の最初のフィールドをどのように選択しますか?
ベストアンサー1
atq | awk '/Oct 29/ { print $1 }'
これにより、文字列を含むジョブのジョブIDが印刷されますOct 29
。
このawk
コードは、各入力行に対して与えられた正規表現を照合し、一致する行に対してその行の最初のスペースで区切られたフィールド(ジョブID)を印刷します。
この短いパイプの結果をxargs atrm
削除操作に渡します。
atq | awk '/Oct 29/ { print $1 }' | xargs atrm
ユーティリティxargs
は、標準入力ストリームからデータを読み込み、読み取った引数を使用して指定されたユーティリティを実行します。もしあればたくさんxargs
ユーティリティはパラメータを使用して複数回実行できます(この場合はそうではありません)。