指定された日付でキューからジョブを削除する

指定された日付でキューからジョブを削除する

キューに一連の保留中のジョブがあります。

$ 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ユーティリティはパラメータを使用して複数回実行できます(この場合はそうではありません)。

おすすめ記事