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

[文本处理] 【已解决】批处理:如何删除出现空格的行

[复制链接]
发表于 2018-8-30 16:35:43 | 显示全部楼层 |阅读模式
本帖最后由 思想之翼 于 2018-8-30 19:13 编辑

文件夹内有若干文本,每文本有4列数据,每列数据TAB间隔且长短不一,格式如下:
2        3        4        5
1        2        3        4
6                  7        3  
                    8
现在欲删除各文本中出现空格的行,结果如下:
2        3        4        5
1        2        3        4
然后覆盖原文本

评分

参与人数 1PB +2 收起 理由
Batcher + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

发表于 2018-8-30 18:21:25 | 显示全部楼层
简单点用 findstr 就好:
  1. type 1.txt | findstr /v /c:" " > 2.txt
复制代码
不用 findstr,判断每一行的列数不小于4
  1. @echo off
  2. (for /f "tokens=1-4" %%a in (1.txt) do (
  3.     if not "%%d" == "" (
  4.         echo;%%a        %%b        %%c        %%d
  5.     )
  6. )) > 2.txt
  7. pause
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享

查看全部评分

 楼主| 发表于 2018-8-31 11:33:11 | 显示全部楼层
简单点用 findstr 就好:不用 findstr,判断每一行的列数不小于4
WHY 发表于 2018-8-30 18:21
findstr怎么运用?直接运行代码无效。
发表于 2018-8-31 13:51:44 | 显示全部楼层
  1. gawk "$4" 1.txt > 2.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享

查看全部评分

发表于 2018-8-31 14:10:12 | 显示全部楼层
  1. @echo off
  2. powershell -c "gc 1.txt | %{if(($_ -split '\s+')[3]){$_}}" > 2.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享

查看全部评分

发表于 2018-8-31 21:14:09 | 显示全部楼层
回复 3# 思想之翼


    我猜你所说的空格并不是指“空格字符”,而是指某一列的值为“空值”。
如果我猜的没错,用 findstr 可以这样:
  1. findstr /r /c:"[0-9][0-9]*[         ][         ]*[0-9][0-9]*[         ][         ]*[0-9][0-9]*[         ][         ]*[0-9][0-9]*" 1.txt > 2.txt
复制代码

评分

参与人数 1技术 +1 收起 理由
思想之翼 + 1 感谢分享

查看全部评分

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

本版积分规则

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

GMT+8, 2026-3-18 18:17 , Processed in 0.020649 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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