スクリプト出力を列から行に変換

スクリプト出力を列から行に変換

データを含むこのようなファイルがあります。

tcp,0,5,server1,1221,server5,0
udp,0,7,server2,4324,server1,0
tcp,2,1,server3,2355,server4,0

以下は私のスクリプトの試用版です。

while true; do
if [[ $first == "2" ]] ; then
read -p "Please input the src IP pattern: " sstr
cat temp | awk -F',' -v pat="$sstr" 'tolower($4) ~ pat {print $4}' 
fi 
if [[ $second == "4" ]] ; then
read -p "Please input the dest IP pattern: " dstr
cat temp | awk -F',' -v pat="$dstr" 'tolower($6) ~ pat {print $6}' 
fi
break
done > $destfile

次の出力

src 
server1
server2
server3
dest
server5
server1
server4

私はそれが欲しい

src dest
server1 server5
server2 server1
server3 server4

ベストアンサー1

awkを介して同じファイルを複数回パイプするのではなく、ファイルを1回繰り返して完全にawkで実行します。たとえば、

#!/bin/bash

# accept src and dst from command line args
# very primitive.  use getopts to do this properly.
[ -n "$1" ] && sstr="$1"
[ -n "$2" ] && dstr="$2"

# if not provided on command line, ask for them
[ -z "$sstr" ] && read -p "Please input the src IP pattern: " sstr
[ -z "$dstr" ] && read -p "Please input the dst IP pattern: " dstr

awk -F, -v src="$sstr" -v dst="$dstr" '
  BEGIN {IGNORECASE=1; print "src dst"};
  $4 ~ src && $6 ~ dst { print $4,$6 }' temp

出力:

$ ./print-both-columns.sh 1 5
src dst
server1 server5

おすすめ記事