Tenho uma série de trabalhos pendentes na fila,
$ 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
e planeja removê-los do trabalho em 29 de outubro. Felizmente, o atrm pode remover vários trabalhos
atrm 8 5 15 4
apesar disso, uma iteração pode ser uma solução melhor,
$ 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
Como eu poderia selecionar o primeiro campo do número do trabalho para iterá-los?
Isso imprimiria os IDs dos trabalhos que contêm a string
Oct 29
.O que o
awk
código está fazendo é combinar a expressão regular fornecida com cada uma das linhas de entrada e, para as linhas correspondentes, imprime o primeiro campo delimitado por espaços em branco na linha (o ID do trabalho).Passar o resultado desse pipeline curto para
xargs atrm
removeria os trabalhos:O
xargs
utilitário lê a partir de seu fluxo de entrada padrão e executa o utilitário fornecido com o argumento read. Se houver muitos argumentos (provavelmente não neste caso),xargs
pode executar o utilitário várias vezes.Você poderia simplesmente canalizar a
atq
saída e processá-la um pouco:O que está sendo feito:
Oct 29
daatq
saídacut
e assumindo um espaço como separadortr
Isso fornece apenas os números do trabalho
at
em uma única linha que pode ser sua entrada paraatrm
.Faça um pré-teste da seleção listando os IDs de trabalho apenas usando