Board logo

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

作者: gannh    时间: 2012-11-22 08:15     标题: [已解决]批处理怎样删除倒数第二列中的指定字符?

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

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

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

作者: gannh    时间: 2012-11-22 09:32

回复 2# tmplinshi


    谢谢版主tmplinshi 的指教
作者: Batcher    时间: 2012-11-22 09:46

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

作者: Batcher    时间: 2012-11-22 09:54

  1. sed -r -i "s/(.* [0-9]+).([0-9]+ [0-9.]+$)/\1\2/" a.txt
复制代码

作者: gannh    时间: 2012-11-22 11:04

回复 5# Batcher


    谢谢指点




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