标题: [文本处理] 批处理如何批量查找只有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
- gawk "NF<=9" 1.txt > 2.txt
复制代码
作者: CrLf 时间: 2015-2-3 14:40
- @echo off
- for /f "delims=" %%a in (a.txt) do (
- for /f "tokens=9,10" %%b in ("%%a") do (
- if %%b%%c==%%b echo %%a
- )
- )
- 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的- @echo off
- ::假设txt都在E:\123\文件夹里,实际自行修改
- cd /d "E:\123\"
- md "9列文档\"
- for /f "delims=" %%a in ('dir /a-d/b *.txt') do (
- for /f "tokens=9,10" %%b in ('type "%%a"') do (
- if "%%b%%c" equ "%%b" copy "%%a" "9列文档\"
- )
- )
- 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代表要存放的目录- @echo off&color f0&setlocal enabledelayedexpansion
- for /f %%i in ('dir /b *.txt') do (
- set m=0
- for /f "delims=" %%a in (%%i) do (
- set /a m+=1
- if !m!==1 (
- for %%j in (%%a) do (
- set /a n+=1
- )
- if !n!==9 (move %%~nxi 9) else move %%~nxi 10
- )
- )
- )
复制代码
回复 1# nihaoareyou
欢迎光临 批处理之家 (http://bathome.net./) |
Powered by Discuz! 7.2 |