[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

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

本帖最后由 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
因为每行的最后两组数据的长度大小不一,我觉得很难用处理来处理(个人能力有限),不知道各位大师能帮帮忙否,感激不尽。。。。谢谢

回复 5# Batcher


    谢谢指点

TOP

  1. sed -r -i "s/(.* [0-9]+).([0-9]+ [0-9.]+$)/\1\2/" a.txt
复制代码
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

  1. gawk "gsub(/\./,\"\",$(NF-1))" a.txt >b.txt
复制代码
1

评分人数

我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 2# tmplinshi


    谢谢版主tmplinshi 的指教

TOP

本帖最后由 tmplinshi 于 2012-11-22 09:13 编辑

删除第五个点:
  1. sed -i "s/\.//5" *.txt
复制代码
删除倒数第二列的点:
  1. sed -i -r "s/\.([^ ]+ [^ ]+)$/\1/" *.txt
复制代码

TOP

返回列表