次のファイルがあります(vimからコピー)。
name: some name^M
^M
count: 1^M
^M
region: some_region
name: some name^M
^M
count: 2^M
^M
region: some_region^M
^M
name: some name^M
^M
count: 1^M
^M
region: some_region^M
^M
Testing Powershell scripts execustions from Rundeck server against Windows server
名前、数、面積の後の値のみを取得する方法
希望の出力:
some name 1 some region
some name 2 some region
some name 1 some region
そして grep -E 'name|count|region' output.txt | sed 's/^.*: //'
私は持っています
some name
1
some_region
some name
2
some_region
some name
1
some_region
複数の列を生成する方法は?
答え1
Awk
解決策:
awk '/^(name|count|region):/{
sep = (/^region/? ORS : OFS);
gsub(/^[^:]+:[[:space:]]*|[[:space:]]*$/, "");
printf "%s%s", $0, sep
}' file.txt
出力:
some name 1 some_region
some name 2 some_region
some name 1 some_region
答え2
2つのステップを経て、上記の結果を得ました。
最初のステップでは、パターンを検索してOutput.txtファイルに保存します。
2番目のステップでは、forループを使用し、要件に応じて内容を印刷しました。
ステップ1
egrep -i "name|count|region" l.txt | awk -F ":" '{print $NF}' | sed "s/\^M//g" >> Ouput.txt
ステップ2
for ((i=1;i<=9;i=i+3)); do sed -n ''$i',+2p' Output.txt |sed "N;s/\n/ /g" |sed "N;s/\n/ /g"; done
出力
some name 1 some_region
some name 2 some_region
some name 1 some_region
答え3
awkを使用して可能な答えの1つ:
awk '/name: /{name=substr($0,7)} /count: /{cnt=substr($0,8)} /region:/{print name" "cnt" "substr($0,9)}' input