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

[文本处理] [已解决]批处理findstr命令多文本数据检索时如何不显示文件名?

假设有3个文本文件,分别为:a1.txt ; a2.txt ; a3.txt
a1.txt 里面的数据是:
1
1

a2.txt里面的数据是:
1
2

a3.txt里面的数据是:
1
3

用findstr "1" a*.txt > b.txt,得到的结果是:
a1.txt:1
a1.txt:1
a2.txt:1
a3.txt:1
它把所有文件面都自动添加到每一行的行首了,我只想要:
1
1
1
1
这样的结果,用for命令说啥也试不出来,请教各位DX,帮帮忙吧。
1

评分人数

    • CrLf: 感谢给帖子标题标注[已解决]字样PB + 2

  1. type a*.txt | findstr "1"
复制代码

TOP

type a*.txt | findstr "1"
tmplinshi 发表于 2011-7-19 14:25


非常感谢,这么简单的一句话就搞定了

再继续问一下,能否返回查询行数,这个例子返回数值4。

再次感谢

TOP

本帖最后由 zm900612 于 2011-7-19 15:45 编辑

3# ftjm268
  1. type a*.txt |findstr /v "a.*\.txt"|find /c "1"
复制代码

TOP

本帖最后由 tmplinshi 于 2011-7-19 16:14 编辑

3# ftjm268
  1. type a*.txt 2>nul | find /c "1" >b.txt
复制代码
2>nul 可要可不要,不会影响结果,不加 2>nul 的话文件名会显示在 cmd 窗口。

TOP

3# ftjm268 type a*.txt |findstr /v "a.*\.txt"|find /c "1"
zm900612 发表于 2011-7-19 15:43

type 输出的文件名,是输出到了 standard error。
1

评分人数

    • zm900612: 这个细节很关键,学习了技术 + 1

TOP

6# tmplinshi


这倒没注意,好技巧!

TOP

可能我没说明白,我是想搜索一下三个文本里面的“1”的数量,然后把结果赋值给一个变量

TOP

  1. @echo off
  2. set nb=0
  3. for /f "tokens=1,*" %%a in ('find "1" *.txt') do if not %%a==---------- echo %%a %%b&&set /a nb+=1
  4. echo 总共:%nb%
  5. pause
复制代码
寂寞是黑白的,但黑白不是寂寞,是永恒。BAT 需要的不是可能,而是智慧。

TOP

shi兄给我的第一个答案,我在测试文件上成功了,但用到真实数据上错了,

真实数据里的查询条件类似:382 -VB814266

条件中有空格,如果用:type 110715*.txt|findstr "382 -VB814266" > sum.txt

则会将以110715开头的文本文件中所有不包括382 -VB814266的数据汇总到sum.txt里,我发誓没用/V开关。

TOP

本帖最后由 tmplinshi 于 2011-7-19 17:29 编辑

因为 findstr "382 -VB814266" 查找的是两个关键词 "382" 和 "-VB814266"。
  1. @echo off
  2. set str="1"
  3. set file="110715*.txt"
  4. type %file% 2>nul | findstr /c:%str% >sum.txt
  5. for /f %%a in (' "type %file% 2>nul | find /c %str%" ') do set n=%%a
  6. echo %n%
  7. pause
复制代码

TOP

  1. @Echo Off
  2. For /F %%a In ('Findstr /c:"382 -VB814266" 110715*.txt') Do Set /A Count+=1
  3. Echo %Count%
  4. Pause>Nul
复制代码
一路飘过的鸟~~~

TOP

因为 findstr "382 -VB814266" 查找的是两个关键词 "382" 和 "-VB814266"。@echo off
set str="1"
set file="110715*.txt"
type %file% 2>nul | findstr /c:%str% >sum.txt
for /f %%a in (' "type %file% 2>nul ...
tmplinshi 发表于 2011-7-19 17:15


shi兄,这段代码还是不行,返回的数据总数是0,

实在不好意思,这两天非常忙,没有时间分析各位老师给的代码,一有时间我一定认真学习大家给我的代码,并且一定会让这个帖子有始有终

再次感谢大家对我的帮助

TOP

@echo off
set str="382 -VB814266"
set file="110715*.txt"
type %file% 2>nul | findstr /c:%str% >sum.txt
for /f %%a in (' "type %file% 2>nul | find /c %str%" ') do set n=%%a
echo %n%
pause


是不是你忘记修改红色部分了?

TOP

是不是你忘记修改红色部分了?
tmplinshi 发表于 2011-7-20 12:24


我修改了变量但返回仍然是0,我把数据源的截屏发上来了,这是我修改了参数的您的代码:
:echo off
u:
cd MTN\OPSDATA_BKUP
set str="382 -v143788"
set file="200718*.txt"
type %file% 2>nul | findstr /c:%str% >sum.txt
for /f %%a in (' "type %file% 2>nul | find /c %str%" ') do set n=%%a
echo %n%
pause

N=0

原来如果是指定文件名,用findstr检索有空格的订单号就可以,现在即便指定文件名是200718_0844.txt也检索不到数据了

请问,这个2>nul是啥意思?

谢谢shi兄。

TOP

返回列表