加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

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列,则必须在循环中执行,或者使用子函数或考虑其他工具,例如.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读