找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 17001|回复: 4

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

[复制链接]
发表于 2014-9-3 08:47:33 | 显示全部楼层 |阅读模式
本帖最后由 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列了,求大神指点

评分

参与人数 1PB +2 收起 理由
Batcher + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

 楼主| 发表于 2014-9-3 08:59:16 | 显示全部楼层
我是不是发错版块了?这里能求助第三方命令吗
发表于 2014-9-3 09:17:07 | 显示全部楼层
  1. @gawk "BEGIN{FS=OFS=","}FNR==1{sub(/\.[^\.]*$/,"A^&",FILENAME)}{$1+=100;print>FILENAME}" *.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
tommytangtang + 1 技术好

查看全部评分

 楼主| 发表于 2014-9-3 09:38:55 | 显示全部楼层
回复 3# DAIC

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

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

懂了,谢谢
发表于 2014-9-3 12:40:27 | 显示全部楼层
回复 4# tommytangtang


    问题解决后,请编辑顶楼帖子在标题前面注明[已解决],并给回答者加分。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-17 00:49 , Processed in 0.018305 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表