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

[文本处理] 批处理怎样提取出txt特定列特定行并保存到一个新txt中

请教高手,如题所示,我需要提取文件夹下500多个txt(空格分隔),需要提取出每个文档 第十列大于500的 行 并保存到一个新的txt中。看论坛上大家的帖子,写了一个,但是运行总是报错。本人新手,求高手指点。感谢~~~~~
  1. $dir = dir D:\\Data\\PRE\\*.TXT
  2. foreach($_ in $dir){
  3. (for /f "delims= "  %%i in $_  do ( if $10 geq 500 echo %%i))
  4. } >>10.txt
复制代码
附件是两个示例文档。麻烦老师们看下。。

回复 1# drunkcat
上传一个有代表性的文本,测试代码用,这样大家更容易帮到你。

TOP

回复 2# qixiaobin0715


    谢谢你的提醒,我已经上传附件了。。

TOP

本帖最后由 路过 于 2021-1-19 14:28 编辑
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. set "mydir=D:\Data\PRE\"
  4. pushd "%mydir%"
  5. (for %%A in (*.txt) do (echo;//%%A:-----------------------
  6.         for /f "usebackq tokens=1-10,*" %%a in ("%%A") do (
  7.             if %%j geq 500 (echo;%%a %%b %%c %%d %%e %%f %%g %%h %%i %%j %%k)
  8.         )
  9.     )
  10. )>result.txt
  11. start result.txt
  12. pause
  13. exit
复制代码

TOP

回复 4# 路过


    谢谢高手!!~~~~太感谢了。我得好好学习这个。。厉害~~感谢感谢

TOP

回复 4# 路过


    谢谢高手!!~~~~太感谢了。我得好好学习这个。。厉害~~感谢感谢

TOP

返回列表