找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 79807|回复: 23

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

[复制链接]
发表于 2011-7-19 14:21:28 | 显示全部楼层 |阅读模式
假设有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,帮帮忙吧。

评分

参与人数 1PB +2 收起 理由
CrLf + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

发表于 2011-7-19 14:25:05 | 显示全部楼层
  1. type a*.txt | findstr "1"
复制代码
 楼主| 发表于 2011-7-19 15:03:29 | 显示全部楼层
type a*.txt | findstr "1"
tmplinshi 发表于 2011-7-19 14:25


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

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

再次感谢
发表于 2011-7-19 15:43:58 | 显示全部楼层
本帖最后由 zm900612 于 2011-7-19 15:45 编辑

3# ftjm268
  1. type a*.txt |findstr /v "a.*\.txt"|find /c "1"
复制代码
发表于 2011-7-19 16:08:22 | 显示全部楼层
本帖最后由 tmplinshi 于 2011-7-19 16:14 编辑

3# ftjm268
  1. type a*.txt 2>nul | find /c "1" >b.txt
复制代码
2>nul 可要可不要,不会影响结果,不加 2>nul 的话文件名会显示在 cmd 窗口。
发表于 2011-7-19 16:11:05 | 显示全部楼层
3# ftjm268 type a*.txt |findstr /v "a.*\.txt"|find /c "1"
zm900612 发表于 2011-7-19 15:43

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

评分

参与人数 1技术 +1 收起 理由
zm900612 + 1 这个细节很关键,学习了

查看全部评分

发表于 2011-7-19 16:16:57 | 显示全部楼层
6# tmplinshi


这倒没注意,好技巧!
 楼主| 发表于 2011-7-19 16:22:11 | 显示全部楼层
可能我没说明白,我是想搜索一下三个文本里面的“1”的数量,然后把结果赋值给一个变量
发表于 2011-7-19 16:26:08 | 显示全部楼层
  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
复制代码
 楼主| 发表于 2011-7-19 16:40:33 | 显示全部楼层
shi兄给我的第一个答案,我在测试文件上成功了,但用到真实数据上错了,

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

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

则会将以110715开头的文本文件中所有不包括382 -VB814266的数据汇总到sum.txt里,我发誓没用/V开关。
发表于 2011-7-19 17:15:29 | 显示全部楼层
本帖最后由 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
复制代码
发表于 2011-7-19 19:09:39 | 显示全部楼层

  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
复制代码
 楼主| 发表于 2011-7-20 12:00:12 | 显示全部楼层
因为 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,

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

再次感谢大家对我的帮助
发表于 2011-7-20 12:24:23 | 显示全部楼层
@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


是不是你忘记修改红色部分了?
 楼主| 发表于 2011-7-20 13:21:30 | 显示全部楼层
是不是你忘记修改红色部分了?
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兄。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-17 19:39 , Processed in 0.028227 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表