Board logo

标题: [问题求助] [已解决]gawk怎么样打印每行第2列以后的数? [打印本页]

作者: tommytangtang    时间: 2014-9-3 08:47     标题: [已解决]gawk怎么样打印每行第2列以后的数?

本帖最后由 tommytangtang 于 2014-9-3 09:39 编辑

文本Text1.txt如下:
23,123,345,234,345,345,456,123
24,345,234,345,345,456,123,123
25,123,345,234,345,345,456,123

打印出来后新文本Text1A.txt如下:
123,123,345,234,345,345,456,123
124,345,234,345,345,456,123,123
125,123,345,234,345,345,456,123

文本里面的数据是没有规律的,每行列数也不一定,所以一定要用到NF
只是第一列统一加100,后面不变

@gawk -F"," "FNR==1{sub(/\.[^\.]*$/,\"A^&\",FILENAME)}{for (i=1;i<=NF;i++)print $1+100,$i>FILENAME}" *.txt

这样打出来都变成2列了,求大神指点
作者: tommytangtang    时间: 2014-9-3 08:59

我是不是发错版块了?这里能求助第三方命令吗
作者: DAIC    时间: 2014-9-3 09:17

  1. @gawk "BEGIN{FS=OFS=\",\"}FNR==1{sub(/\.[^\.]*$/,\"A^&\",FILENAME)}{$1+=100;print>FILENAME}" *.txt
复制代码

作者: tommytangtang    时间: 2014-9-3 09:38

回复 3# DAIC

哦,要先替换某个$,然后打出替换后的整个$0

原文本以“,”分割需要用FS读取,输出“,”要用OFS设定

懂了,谢谢
作者: DAIC    时间: 2014-9-3 12:40

回复 4# tommytangtang


    问题解决后,请编辑顶楼帖子在标题前面注明[已解决],并给回答者加分。




欢迎光临 批处理之家 (http://www.bathome.net/) Powered by Discuz! 7.2