Board logo

标题: [文本处理] 批处理如何批量查找只有9列数据的txt文本文件? [打印本页]

作者: nihaoareyou    时间: 2015-2-3 11:26     标题: 批处理如何批量查找只有9列数据的txt文本文件?

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

我有很多txt文件,有些有10列数据,有些有9列数据,怎么批量筛选出其中包含9列数据的txt?
数据都是用空格分开的。
作者: DAIC    时间: 2015-2-3 13:14

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

作者: CrLf    时间: 2015-2-3 14:40

  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
复制代码

作者: nihaoareyou    时间: 2015-2-3 14:44

回复 2# DAIC


    请问这个具体怎么操作啊?
作者: nihaoareyou    时间: 2015-2-3 14:49

回复 3# CrLf


    这个运行不成功,显示系统找不到“a.txt”文件。
作者: pcl_test    时间: 2015-2-3 16:18

本帖最后由 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
复制代码

作者: terse    时间: 2015-2-3 16:29

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

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

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




欢迎光临 批处理之家 (http://www.bathome.net/) Powered by Discuz! 7.2