假设我们有一个 shell 变量,$x其中包含一个以空格分隔的 1 到 30 数字列表:
$ x=$(for i in {1..30}; do echo -n "$i "; done)
$ echo $x
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
Run Code Online (Sandbox Code Playgroud)
我们可以像这样用 AWK 打印前三个输入记录字段:
$ echo $x | awk '{print $1 " " $2 " " $3}'
1 2 3
Run Code Online (Sandbox Code Playgroud)
我们如何使用 AWK 打印从第 N 个字段开始的所有字段?例如
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
Run Code Online (Sandbox Code Playgroud)
编辑:我可以使用 cut、sed 等来做同样的事情,但在这种情况下,我想知道如何使用 AWK 来做到这一点。
将我的评论转换为答案,以便将来的访问者轻松找到解决方案。
你可以使用这个awk:
awk '{for (i=3; i<=NF; ++i) printf "%s", $i (i<NF?OFS:ORS)}' file
Run Code Online (Sandbox Code Playgroud)
或将开始位置作为参数传递:
awk -v n=3 '{for (i=n; i<=NF; ++i) printf "%s", $i (i<NF?OFS:ORS)}' file
Run Code Online (Sandbox Code Playgroud)