给定以下命令,
echo "1: " | awk '/1/ -F ":" {print $1}'
为什么AWK输出:
1:
?
给定以下命令,
echo "1: " | awk '/1/ -F ":" {print $1}'
为什么AWK输出:
1:
?
当前回答
-F是awk本身的参数:
$echo "1: " | awk -F":" '/1/ {print $1}'
1
其他回答
AWK是一个文本解释器,它对整个文档进行逐行处理,对每一行进行逐域处理。因此$1,$2…$n是对每行字段的引用($1是第一个字段,$2是第二个字段,依此类推……)
您可以通过在命令行下使用“-F”开关或在两个括号内使用“FS=…”来定义字段分隔符。
现在考虑Jürgen的答案:
echo "1: " | awk -F ":" '/1/ {print $1}'
在字段上方,边界由“:”设置,因此我们有两个字段$1是“1”,$2是空白区域。后面是正则表达式“/1/”,它指示过滤器只有在解释器偶然发现包含这样一个表达式的行(我的意思是1)时才输出第一个字段。
“echo”命令的输出是一行包含“1”,因此过滤器将工作…
在处理以下示例时:
echo "1: " | awk '/1/ -F ":" {print $1}'
语法混乱,解释器选择忽略部分F“:” 并切换到默认的字段分割器,即空白区域,因此输出“1:”作为第一个字段,并且不会有第二个字段!
Jürgen的答案包含了良好的语法…
你有多种方法来设置:作为分隔符:
awk -F: '{print $1}'
awk -v FS=: '{print $1}'
awk '{print $1}' FS=:
awk 'BEGIN{FS=":"} {print $1}'
它们都是等价的,并且在输入“1:2:3”的情况下将返回1:
$ awk -F: '{print $1}' <<< "1:2:3"
1
$ awk -v FS=: '{print $1}' <<< "1:2:3"
1
$ awk '{print $1}' FS=: <<< "1:2:3"
1
$ awk 'BEGIN{FS=":"} {print $1}' <<< "1:2:3"
1
如果你想通过编程来实现,你可以使用FS变量:
echo "1: " | awk 'BEGIN { FS=":" } /1/ { print $1 }'
注意,如果在主循环中而不是在BEGIN循环中更改它,它将对读入的下一行产生影响,因为当前行已经被分割了。
echo "1: " | "456:abc:515:xyz "
awk -F: NF=/1/
1 | 456
更新:意识到我之前的回答有多啰嗦
-F是awk本身的参数:
$echo "1: " | awk -F":" '/1/ {print $1}'
1