[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] 批处理怎样统计文本行,删除多余的文本

有很多个文本,每个文本内容有1-100行
文本内容如下
文本1 有2行内容
1230 4676 466 198
456  946 491 19833
文本2 有4行内容
132 给你  164 1916
46431  1916   1943  996
111
222
文本3 有10行内容
1111111.11111.11111 11111
3333.2222 222 222 2 2  111
1333
1333
1333
1223
1222
12222
1
1

很多文本我只想找到4行的文本 保留下来其他的都文本都删除

  1. @echo off
  2. for /r %%a in (*.txt) do (
  3. set "fname=%%a"
  4. call :countLines
  5. )
  6. pause&&exit /b
  7. :countLines
  8. for /f "delims=[]" %%i in ('find /n /v ".*"^<"%fname%"') do (
  9. set count==%%i
  10. if !%%i! gtr 4 goto :dealFile
  11. )
  12. :dealFile
  13. if %count% equ 4 exit /b
  14. del /f /q "%fname%"
复制代码
涉及删除操作,请当心
1

评分人数

    • ai8866: 乐于助人,感谢技术 + 1
QQ 33892006

TOP

本帖最后由 WHY 于 2020-8-20 20:13 编辑
  1. @echo off
  2. for /f "tokens=1*" %%i in ('find /c /v "" *.txt') do (
  3.    for /f "tokens=1,2 delims=:" %%a in ("%%j") do (
  4.        if "%%b" NEQ " 4" echo;del "%%a"
  5.    )
  6. )
  7. pause
复制代码

TOP

十分感谢大神

TOP

返回列表