Board logo

标题: [文本处理] 批处理如何从txt文件中找到含有“XYZ”的字符? [打印本页]

作者: ccxiuxiu    时间: 2012-10-30 08:10     标题: 批处理如何从txt文件中找到含有“XYZ”的字符?

请高手帮帮小妹!
求批处理程序,要求如下:
批处理程序1
在目录下有TEXT.txt .
1、在text.txt文件中找到含有“XYZ”的字符,将该字符所在行提取并在目录B下重新生成一个新文件。如果文件中含有该字符有多行,则新文件顺序递增自动命名为1.txt,2.txt,3.txt...。
2、如果某行中有多个“xyz”字符,只生成一个文件。

批处理程序2.
1、想将text.txt文件里寻找“xyz”字符的上一行提取出来并统一放入新文件。

求各位哥哥、姐姐们进来看看,谢谢各位。小妹在线等!!
作者: apang    时间: 2012-10-30 12:34

  1. @echo off&setlocal enabledelayedexpansion
  2. md "B" 2>nul
  3. for /f "delims=" %%a in ('find /i "xyz"^<test.txt') do (
  4.   set /a n+=1
  5.   echo,%%a>"B\!n!.txt"
  6. )
复制代码
  1. @echo off&setlocal enabledelayedexpansion
  2. (for /f "delims=" %%a in (test.txt) do (
  3.   set "a=!b!"
  4.   set "b=%%a"
  5.   if defined a if "!b:xyz=!" neq "!b!" echo,!a!
  6. ))>test1.txt
复制代码

作者: ccxiuxiu    时间: 2012-10-30 21:20

感谢高手热心帮忙,尽管我已经找朋友帮我搞定了。依然感谢apang 。
作者: wc726842270    时间: 2012-10-31 03:40

回复 3# ccxiuxiu


    能不能把你的方法共享一下,




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