Board logo

标题: [文本处理] 求一个记事本数字替换的批处理 [打印本页]

作者: clq168    时间: 2013-11-18 18:27     标题: 求一个记事本数字替换的批处理

大家好!有问题请教!求一个批处理!
在记事本中阿拉伯数字 超过9999的一律替换为9999!

作者: Batcher    时间: 2013-11-18 18:47

请给一段文本内容以便测试代码
作者: clq168    时间: 2013-11-19 08:05     标题: 求一个记事本数字替换的批处理

本帖最后由 clq168 于 2013-11-19 15:31 编辑

跪求一个批处理!
在记事本中阿拉伯数字 超过9999的一律替换为9999!
请看附件
作者: clq168    时间: 2013-11-19 08:09

上面是测试代码!比如I187.595 J10228.147
I 和j   后面的数字 不论正负超过9999机床就会不读让后停机报警,请高手帮忙把正负超过9999的I和J后面的数字全部替换为9999
感激不尽!
谢谢!
作者: clq168    时间: 2013-11-19 08:11

超过9999的I和J后面的数字全部替换为9999
感激不尽!
谢谢!
作者: DAIC    时间: 2013-11-19 08:25

回复 4# clq168


    数字里面的点是表示小数点吗?187.595没有超过9999吧?
作者: apang    时间: 2013-11-19 11:31

本帖最后由 apang 于 2013-11-19 16:18 编辑
  1. Set fso = CreateObject("Scripting.FileSystemObject")
  2. text = fso.OpenTextFile("a.nc",1).ReadAll
  3. Set re = New RegExp
  4. re.Pattern = "([IJ](?:|\-))([1-9]\d{4,}(?:|\.\d*)|9999\.\d+)(\s)"
  5. re.IgnoreCase = True
  6. re.Global = True
  7. text = re.Replace(text,"$19999$3")
  8. fso.OpenTextFile("b.txt",2,True).Write text
  9. MsgBox "OK"
复制代码

作者: clq168    时间: 2013-11-19 14:54

谢谢楼上的高手!可是我用不起来!
冒昧的请求一下!如果您有空请看一下我的附件里名为a的文件(其实就是一段加工中心的程序代码),里面有超过9999的数字!
因为人工找经常会漏掉!反复操作比较浪费时间!

在记事本中阿拉伯数字 超过9999的一律替换为9999
及时是9999.01也要替换为9999整数

作者: clq168    时间: 2013-11-19 15:25

补充一下!比如I187.595 J10228.147
I 和J 后面的数字 超过9999的数字全部替换为9999的整数!

感激不尽!
谢谢!
作者: clq168    时间: 2013-11-19 15:28

补上图片
作者: DAIC    时间: 2013-11-19 16:03

回复 8# clq168


    7楼的代码你是怎样执行的?
作者: apang    时间: 2013-11-19 16:21

回复 10# clq168


    哦,没考虑9999.01的情况,以修改
代码保存为test.vbs,试试
作者: clq168    时间: 2013-11-19 21:06

非常感谢!非常好用!果然高手在民间! :victory:




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