我在 shell 脚本中使用 awk,它按预期工作。
awk -F'^' 'BEGIN {OFS="^"} {print $1,$2,$3,$4,$5}'
当我需要更改列数时,我只需通过添加 $6,$7,$8 来更改打印语句
有没有办法在变量中声明它并在 awk 中使用该变量?
columns=8
awk -F'^' 'BEGIN {OFS="^"} {print $1..$columns}'
我在 shell 脚本中使用 awk,它按预期工作。
awk -F'^' 'BEGIN {OFS="^"} {print $1,$2,$3,$4,$5}'
当我需要更改列数时,我只需通过添加 $6,$7,$8 来更改打印语句
有没有办法在变量中声明它并在 awk 中使用该变量?
columns=8
awk -F'^' 'BEGIN {OFS="^"} {print $1..$columns}'
通过定义一个函数来做到这一点。
awk 'function col(s,e){ret="";for(i=s;i<=e;i++){ret=ret" "$i}return ret}{print col(2,6)}'
您可以使用 指定 shell 变量awk -v
,然后遍历所有列:
awk -v cols="$columns" '{ for (i=1; i<=cols; i++) printf (i!=cols) ? $i OFS : $i"\n" }' file.txt
你总是可以使用for
-loop
{for(i=1;i<=columns;i++)printf("%s ", $i);print '\n'}'
usingprintf
和print
after 循环将为您提供行尾的换行符。
这可能对您有用:
echo 1 2 3 4 5 6 7 8 9 | awk -vnf=5 '{NF=nf}1'
1 2 3 4 5