250,000のジョブの詳細を含むファイルがあります。このソースファイルでは、すべてのジョブに異なるパラメータがあるため、ジョブごとに行数が異なる場合があります。唯一のパターンは、各ジョブ定義がブレークラインで始まり、insert:
ブレークラインで終わることです。
insert: PPC_SA1 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
std_err_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.err"
alarm_if_fail: 1
group: P
resources:
insert: PPC_SA2 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
insert: PPC_SA3 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
insert: PPC_SA4 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
std_err_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.err"
alarm_if_fail: 1
group: P
resources:
insert: PPC_SA5 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
insert: PPC_SA6 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
目標位置:
PPC_SA1
PPC_SA5
PPC_SA3
上記のリストにあるこれらの操作のエントリを別のファイルに抽出する必要があります。
insert: PPC_SA1 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
std_err_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.err"
alarm_if_fail: 1
group: P
resources:
insert: PPC_SA5 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
insert: PPC_SA3 job_type: CMD
box: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
ベストアンサー1
タスクはすべて空行で終わるため、perl
「段落モード」で使用できます(つまり、空行を\n\n
レコード区切り文字と見なし、「段落」を「行」として効果的に処理することを意味します)。
$ perl -00lne 'print if /insert:\s+PPC_SA[153]\s/' file
insert: PPC_SA1 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
std_err_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.err"
alarm_if_fail: 1
group: P
resources:
insert: PPC_SA3 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
insert: PPC_SA5 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
段落モードを有効にする-00
と、スクリプトは一致するすべてのレコードを印刷し、その後にまたはinsert:\s+PPC_SA
いずれかと別の空白文字が続きます。1
5
3
もちろん、ターゲットIDが多いと実用的ではないので、次のように一般化することもできます。
cat file |
perl -00lne 'BEGIN{ $k{$_}++ for @ARGV; @ARGV=()} /insert:\s+(\S+)/; print if $k{$1}' PPC_SA1 PPC_SA5 PPC_SA3
または を使用して、宛先 ID を 1 行に 1 つずつawk
ファイル (この例では呼び出される) に保存し、以下を実行できます。target_ids
$ awk '(NR==FNR){a[$1]++; next}
{
if(/insert:/ && $2 in a){want=1}
if(want){print}
if(/^\s*$/){want=0}
}' target_ids file
insert: PPC_SA1 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
std_err_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.err"
alarm_if_fail: 1
group: P
resources:
insert: PPC_SA3 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0
description: "Run program"
std_out_file: "/home/PROD/autosys/logs/${AUTO_JOB_NAME}_`date +%y%m%d`.log"
insert: PPC_SA5 job_type: CMD
name: PPC
command: sa
machine: P
owner: cat
permission:
date_conditions: 0