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

[文本处理] [已解决]批处理怎样删除倒数第二列中的指定字符?

[复制链接]
发表于 2012-11-22 08:15:45 | 显示全部楼层 |阅读模式
本帖最后由 gannh 于 2014-5-31 15:09 编辑

现有多个文本文件,文件内容如下
20121029 0335 4.94 4.94 4.90 4.92 1510.00 742824.750
20121029 0440 4.92 4.93 4.91 4.92 907.00 158.125
20121029 0645 4.93 4.94 4.92 4.93 338.00 166857.87
20121029 0850 4.92 4.94 4.92 4.92 416.00 76.500
20121029 0755 4.92 4.93 4.92 4.93 922.00 453857.000
我想将每行的倒数第二组数据中(以空格为分隔线为一组),倒数第三个字符.批量去掉,如
20121029 0335 4.94 4.94 4.90 4.92 151000 742824.750
20121029 0440 4.92 4.93 4.91 4.92 90700 158.125
20121029 0645 4.93 4.94 4.92 4.93 33800 166857.87
20121029 0850 4.92 4.94 4.92 4.92 41600 276.500
20121029 0755 4.92 4.93 4.92 4.93 92200 453857.000
因为每行的最后两组数据的长度大小不一,我觉得很难用处理来处理(个人能力有限),不知道各位大师能帮帮忙否,感激不尽。。。。谢谢
发表于 2012-11-22 09:02:14 | 显示全部楼层
本帖最后由 tmplinshi 于 2012-11-22 09:13 编辑

删除第五个点:
  1. sed -i "s/\.//5" *.txt
复制代码
删除倒数第二列的点:
  1. sed -i -r "s/\.([^ ]+ [^ ]+)$/\1/" *.txt
复制代码
 楼主| 发表于 2012-11-22 09:32:28 | 显示全部楼层
回复 2# tmplinshi


    谢谢版主tmplinshi 的指教
发表于 2012-11-22 09:46:21 | 显示全部楼层
  1. gawk "gsub(/\./,"",$(NF-1))" a.txt >b.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
tmplinshi + 1 学习了

查看全部评分

发表于 2012-11-22 09:54:15 | 显示全部楼层
  1. sed -r -i "s/(.* [0-9]+).([0-9]+ [0-9.]+$)/\1\2/" a.txt
复制代码
 楼主| 发表于 2012-11-22 11:04:18 | 显示全部楼层
回复 5# Batcher


    谢谢指点
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-21 05:27 , Processed in 0.030054 second(s), 18 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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