shell – 删除第一列,然后在awk中保持原始线不变
发布时间:2020-12-15 22:43:46 所属栏目:安全 来源:网络整理
导读:我正在尝试使用awk删除文本文件中的前三个字段.删除前三个字段很容易.但是线路的其余部分被awk搞砸了:分隔符从一个标签变为另一个空格 这是我尝试过的: head pivot.threeb.tsv | awk 'BEGIN {IFS="t"} {$1=$2=$3=""; print }' 前三列已正确删除.问题是输
我正在尝试使用awk删除文本文件中的前三个字段.删除前三个字段很容易.但是线路的其余部分被awk搞砸了:分隔符从一个标签变为另一个空格
这是我尝试过的: head pivot.threeb.tsv | awk 'BEGIN {IFS="t"} {$1=$2=$3=""; print }' 前三列已正确删除.问题是输出结束时,列$4 $5 $6等之间的选项卡转换为空格. 解决方法
首先,如ED评论,你必须在awk中使用FS作为字段分隔符.
选项卡在输出中变为空格,因为您没有定义OFS. awk 'BEGIN{FS=OFS="t"}{$1=$2=$3="";print}' file 这将删除前3个字段,并将其余文本保持为“未触动”(您将看到前3个选项卡).也在输出< tab>会保留. awk 'BEGIN{FS=OFS="t"}{print $4,$5,$6}' file 将输出没有前导空格/制表符.但是如果您有500列,则必须在循环中执行,或者使用子函数或考虑其他工具,例如. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |