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

[问题求助] [已解决]vbs如何实现在txt文本行与行之间插入/添加空行或删除所有空行

[复制链接]
发表于 2014-9-10 20:18:24 | 显示全部楼层 |阅读模式
本帖最后由 pcl_test 于 2016-7-22 22:10 编辑

放某文件夹后执行可以对这个文件夹内的TXT进行操作。
运行后出现两个选项,第一个添加空行,第二个删除空行,可以任意选择功能执行。
发表于 2014-9-10 22:13:16 | 显示全部楼层
空行加在什么地方?
你需要VBS还是BAT呢?
 楼主| 发表于 2014-9-11 11:26:14 | 显示全部楼层
VBS的,TXT内容没有空行,所以行之间隔都要添加空行,第二个是删除所有空行
发表于 2014-9-11 14:57:28 | 显示全部楼层
本帖最后由 apang 于 2014-9-11 19:53 编辑
  1. Dim strPrompt, strInput
  2. strPrompt = "1.插入空行" & vbLf & "2.删除空行" & vbLf & vbLf & "输入1或2"
  3. Do while true
  4.     strInput = InputBox(strPrompt, "", "1")
  5.     If IsEmpty(strInput) Then
  6.         WScript.Quit
  7.     ElseIf strInput = "1" or strInput = "2" Then
  8.         Exit Do
  9.     End If
  10. Loop

  11. Dim fso, file, f, txt
  12. Set fso = CreateObject("Scripting.FileSystemObject")
  13. For Each file In fso.GetFolder(".").Files
  14.     If LCase(Right(file, 4)) = ".txt" Then
  15.         Set f = fso.OpenTextFile(file)
  16.         txt = f.ReadAll
  17.         f.Close
  18.         Set f = Nothing
  19.         If strInput = "1" Then
  20.             txt = RegEx(txt, "\r\n", "$&$&")
  21.         Else
  22.             txt = RegEx(txt & vbCrLf, "(\s*\n)+", vbCrLf)
  23.             If Left(txt, 2) = vbCrLf Then txt = Mid(txt, 3)
  24.         End If
  25.         fso.OpenTextFile(file, 2).Write txt
  26.     End If
  27. Next

  28. MsgBox "OK"

  29. Function RegEx(s, pattern, s1)
  30.     Dim re
  31.     Set re = New RegExp
  32.     re.Pattern = pattern
  33.     re.Global = true
  34.     RegEx = re.Replace(s, s1)
  35. End Function
复制代码

评分

参与人数 1技术 +1 收起 理由
老卡机 + 1 谢谢,很强大,BAT的好慢,这个快多了

查看全部评分

发表于 2015-2-7 12:21:06 | 显示全部楼层
学习了,正好要用
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-17 15:17 , Processed in 0.018908 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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