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

[文本处理] 批处理如何批量查找只有9列数据的txt文本文件?

本帖最后由 pcl_test 于 2016-11-3 17:05 编辑

我有很多txt文件,有些有10列数据,有些有9列数据,怎么批量筛选出其中包含9列数据的txt?
数据都是用空格分开的。

  1. gawk "NF<=9" 1.txt > 2.txt
复制代码

TOP

  1. @echo off
  2. for /f "delims=" %%a in (a.txt) do (
  3.    for /f "tokens=9,10" %%b in ("%%a") do (
  4.       if %%b%%c==%%b echo %%a
  5.    )
  6. )
  7. pause
复制代码

TOP

回复 2# DAIC


    请问这个具体怎么操作啊?

TOP

回复 3# CrLf


    这个运行不成功,显示系统找不到“a.txt”文件。

TOP

本帖最后由 pcl_test 于 2016-11-4 00:59 编辑

回复 5# nihaoareyou

引用CrLf的
  1. @echo off
  2. ::假设txt都在E:\123\文件夹里,实际自行修改
  3. cd /d "E:\123\"
  4. md "9列文档\"
  5. for /f "delims=" %%a in ('dir /a-d/b *.txt') do (
  6. for /f "tokens=9,10" %%b in ('type "%%a"') do (
  7. if "%%b%%c" equ "%%b" copy "%%a" "9列文档\"
  8.    )
  9. )
  10. pause
复制代码

TOP

本帖最后由 terse 于 2015-2-3 16:33 编辑

楼主是要把9列数据提取出来吗?
还是要把含9列的文本COPY出来?
看现在的回复情况是一个文本里有9列也有10列这样混合数据;还是9列和10列数据分开的。
貌似上面COPY多次的哦
忽然发现我打的字比楼主还多

TOP

txt文件和代码在同一个目录下,9和10代表要存放的目录
  1. @echo off&color f0&setlocal enabledelayedexpansion
  2. for /f %%i in ('dir /b *.txt') do (
  3. set m=0
  4. for /f "delims=" %%a in (%%i) do (
  5. set /a m+=1
  6. if !m!==1 (
  7. for %%j in (%%a) do (
  8. set /a n+=1
  9. )
  10. if !n!==9 (move %%~nxi 9) else move %%~nxi 10
  11. )
  12. )
  13. )
复制代码
回复 1# nihaoareyou

TOP

返回列表