标题: [文本处理] 【已解决】批处理:如何删除出现空格的行 [打印本页]
作者: 思想之翼 时间: 2018-8-30 16:35 标题: 【已解决】批处理:如何删除出现空格的行
本帖最后由 思想之翼 于 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
然后覆盖原文本
作者: WHY 时间: 2018-8-30 18:21
简单点用 findstr 就好:- type 1.txt | findstr /v /c:" " > 2.txt
复制代码
不用 findstr,判断每一行的列数不小于4- @echo off
- (for /f "tokens=1-4" %%a in (1.txt) do (
- if not "%%d" == "" (
- echo;%%a %%b %%c %%d
- )
- )) > 2.txt
- pause
复制代码
作者: 思想之翼 时间: 2018-8-31 11:33
简单点用 findstr 就好:不用 findstr,判断每一行的列数不小于4
WHY 发表于 2018-8-30 18:21
findstr怎么运用?直接运行代码无效。
作者: Batcher 时间: 2018-8-31 13:51
复制代码
作者: Batcher 时间: 2018-8-31 14:10
- @echo off
- powershell -c "gc 1.txt | %{if(($_ -split '\s+')[3]){$_}}" > 2.txt
复制代码
作者: WHY 时间: 2018-8-31 21:14
回复 3# 思想之翼
我猜你所说的空格并不是指“空格字符”,而是指某一列的值为“空值”。
如果我猜的没错,用 findstr 可以这样:- findstr /r /c:"[0-9][0-9]*[ ][ ]*[0-9][0-9]*[ ][ ]*[0-9][0-9]*[ ][ ]*[0-9][0-9]*" 1.txt > 2.txt
复制代码
欢迎光临 批处理之家 (http://www.bathome.net/) |
Powered by Discuz! 7.2 |