awk – 仅将函数应用于一列,具有可变位置
发布时间:2020-12-14 00:52:58 所属栏目:Linux 来源:网络整理
导读:我有一堆不同的文件.所有文件都包含标题为ID的列,但不一定在所有文件的同一位置.我有一个函数,我想在所有文件中应用ID,将它们更改为NEWID. 我知道,如果我传入ID的列号,我可以非常简单地做到这一点,说它是5列文件中的第3列,类似于: awk -v column=$COLNUMBER
我有一堆不同的文件.所有文件都包含标题为ID的列,但不一定在所有文件的同一位置.我有一个函数,我想在所有文件中应用ID,将它们更改为NEWID.
我知道,如果我传入ID的列号,我可以非常简单地做到这一点,说它是5列文件中的第3列,类似于: awk -v column=$COLNUMBER '{print $1,$2,FUNCTION($column),$4,$5}' FILE 但是,如果我的所有文件都有数百个列,并且每个文件中都有任意位置,那就非常繁琐了.我正在寻找一种方法来做一些事情: awk -v column=$COLNUMBER '{print #All columns before $column,#All columns after $column}' FILE 我尝试过不同的循环,但尚未开始工作. 解决方法
简单:
$awk -v column=$COLNUMBER '{ $column = FUNCTION($column); print }' $FILE (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |