Board logo

标题: [文件操作] 【已解决】批处理如何删除多个文本里指定列/字段的内容为指定字符串的行 [打印本页]

作者: shero    时间: 2016-11-9 19:51     标题: 【已解决】批处理如何删除多个文本里指定列/字段的内容为指定字符串的行

批量删除txt文件里第二列为0的行数据!!
有很多个文件 一个文件里面有很多txt

格式基本一样
请问想要筛选分离出 删除每个txt文件里面第二例为0的行
作者: pcl_test    时间: 2016-11-9 20:26

本帖最后由 pcl_test 于 2016-11-10 10:27 编辑

for/findstr
http://www.bathome.net/thread-2189-1-1.html
http://bbs.bathome.net/thread-31727-1-1.html
http://www.bathome.net/thread-5814-1-1.html
http://www.bathome.net/viewthread.php?tid=14682
http://www.bathome.net/thread-75-1-1.html
  1. rem win7及以上系统运行
  2. 2>nul md "result\"
  3. powershell -c "dir *.txt|%%{gc $_|?{($_.trim() -split '\s+')[1] -ne 0}|out-file $('result\'+$_.Name) -encoding default}"
  4. rem powershell -c "dir *.txt|%%{gc $_|?{$_ -notmatch '^\s*?\S+?\s+?0[^0]*?'}|out-file $('result\'+$_.Name) -encoding default}"
  5. pause
复制代码

作者: 0000    时间: 2016-11-9 21:14

本帖最后由 0000 于 2016-11-9 21:15 编辑
  1. rem 请把__tab__换成实际的tab字符
  2. set tab=__tab__
  3. for %%a in (*.txt) do (
  4. for /f "tokens=1,2,* delims=%tab%" %%x in (%%a) do (
  5. if not "%%y" == "0" echo %%x%tab%%%y%tab%%%z>>%%~na_1.txt
  6. )
  7. )
复制代码
如有错误请指正。
作者: shero    时间: 2016-11-11 15:32

回复 2# pcl_test


    根据你的代码,我成功完成操作,万分感谢!现在还有一个问题,如果我是想保留第二列是0的行的数据该如何操作呢,请大神指教!
作者: Batcher    时间: 2016-11-11 17:26

回复 3# 0000


咱们论坛可以支持 tab 字符,你试试
  1. set tab=
  2. for %%a in (*.txt) do (
  3.     for /f "tokens=1,2,* delims=%tab%" %%x in (%%a) do (
  4.         if not "%%y" == "0" echo %%x%tab%%%y%tab%%%z>>%%~na_1.txt
  5.     )
  6. )
复制代码

作者: pcl_test    时间: 2016-11-11 18:32

本帖最后由 pcl_test 于 2018-4-19 11:48 编辑

回复 4# shero

1、powershell
-eq
-match
2、
  1. @echo off
  2. for /f "tokens=*" %%a in ('type "文本.txt"') do (
  3.     for /f "tokens=1,2" %%b in ("%%a") do (
  4.         if "%%c" equ "0" echo;%%a
  5.     )
  6. )
  7. pause
复制代码
3、
  1. findstr /rc:"^[ ]*[^ ][^ ]*[ ][ ]*0[^0]*" "文本.txt"
  2. pause
复制代码
4、
  1. #*第三方http://www.bathome.net/s/tool/index.html?key=gawk
  2. #*&cls&2>nul md "result\" &dir /a-d/b *.txt|gawk -f "%~f0"&pause&exit
  3. BEGIN{
  4.    while(getline file>0){
  5.       while(getline<file>0){
  6.           if($2==0)print $0>"result\\"file
  7.       }
  8.    }
  9. }
复制代码

作者: shero    时间: 2016-11-13 08:12

回复 6# pcl_test


    版主大大,我没有明白你的意思,是这几个分别运行还是合在一起,我都试过了还是有问题,原谅我是一个初学者,请大大指导
作者: shero    时间: 2016-11-16 15:19

回复 6# pcl_test


   版主大大 只有第一个程序 把“文本.txt”改为对应的文本可以用,但是只能一个一个文本改吗?不能直接批处理文件夹类的所有txt文件吗?
作者: pcl_test    时间: 2016-11-16 15:50

回复 8# shero

先把2楼发的教程学习学习吧
作者: shero    时间: 2016-11-17 21:58

回复 9# pcl_test


    版主 版主 我根据您之前的程序修改了一下 似乎改出来了 好开心❤
rem win7及以上系统运行
2>nul md "result\"
powershell -c "dir *.txt|%%{gc $_|?{($_.trim() -split '\s+')[1] -eq 0}|out-file $('result\'+$_.Name) -encoding default}"
rem powershell -c "dir *.txt|%%{gc $_|?{$_ -notmatch '^\s*?\S+?\s+?0[^0]*?'}|out-file $('result\'+$_.Name) -encoding default}"
pause
作者: pcl_test    时间: 2016-11-17 22:17

回复 10# shero

这是两段代码,改其一皆可,rem表示注释




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