awk命令可以按分隔符输出不同的列
时间: 2023-07-13 19:35:55 浏览: 44
是的,awk命令可以按照指定的分隔符将一行数据划分为不同的列,并且可以通过$符号来引用每一列数据。例如,假设我们有以下文本文件test.txt:
```
apple,5,1.5
banana,3,2.0
orange,4,1.2
```
如果我们想要输出每一行中的第一列和第三列,可以使用awk命令:
```
awk -F ',' '{print $1, $3}' test.txt
```
其中-F参数指定分隔符为逗号,$1表示第一列,$3表示第三列,输出结果如下:
```
apple 1.5
banana 2.0
orange 1.2
```
相关问题
awk如何按分隔符打印后 输出也将分隔符打印出来
如果想要在awk按分隔符打印后同时输出分隔符,可以在打印时使用`OFS`和`ORS`变量,它们分别表示输出字段分隔符和输出记录分隔符。例如,以下命令将以冒号为分隔符,输出/etc/passwd文件中的第一列和第三列,并且在每个字段之间输出冒号,每行输出后添加一个换行符:
```
awk -F: '{print $1,":",$3}' OFS="" ORS="\n" /etc/passwd
```
输出结果类似于:
```
root:0
daemon:1
bin:2
sys:3
...
```
在这个命令中,`OFS=""`表示输出字段分隔符为空,`ORS="\n"`表示输出记录分隔符为换行符。在打印时,我们在每个字段之间输出冒号,这样输出就会包含原始的分隔符。
awk输出第二列第三列的时候保留分隔符
如果您想要保留第二列和第三列之间的分隔符,可以使用 `substr` 函数来截取特定位置的字符串,并使用 `match` 函数来匹配第二列和第三列之间的分隔符。以下是一个示例 awk 命令:
```shell
awk '{match($0, $2 "[^ ]*"); match($0, $3 "[^ ]*"); print substr($0, RSTART, RLENGTH)}' 文件名
```
这个命令使用 `match` 函数来匹配第二列和第三列之间的分隔符,并使用 `substr` 函数来截取该部分字符串。请将 `文件名` 替换为您要处理的文件名。