[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]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

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


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

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

再次感谢

TOP

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

TOP

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

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

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

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

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

是不是你忘记修改红色部分了?
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

本帖最后由 ftjm268 于 2011-7-20 13:26 编辑

发了图,没想到压缩到这么模糊,我还是用文字说明吧
文件名:200718_0844.txt这个文件有382 -v143788这个订单,但即便用:
findstr "382 -v143788" 200718_0844.txt > sum.txt 或者:
findstr /c:"382 -v143788" 200718_0844.txt > sum.txt都检索不到数据

TOP

16# ftjm268  
如果你不介意的话,你发一小段你的文件内容上来分析,当然,为防止泄密,你可以修改一下,将其他一些无用的内容替换。
这应该是最快的方法,免得你说不清楚我们也搞不懂。
cjiabing 发表于 2011-7-20 13:31


SQ023F|3|U|107 -D1028343|000057|000|X5|X|||802|P02|050|PSHD-999  +|A||20110715|000
SQ023A|3|A|382 -V143788||000|||10||1184||20110715|20110715|0000000||946179|V143788|20110715||E|OT||||AF|Y|F27|20110916|005|2|X||382|030|060|030||000|000|000||000|000|000||000|000|000|000|N|0|1|2|B|V143788||20110715|000

好的,我就发两行吧,有个案例就好,我要第二行订单号是:382 -V143788的整行数据。

TOP

加上 /i 参数忽略大小写:


-------------------

2>nul 是用来屏蔽错误输出。
tmplinshi 发表于 2011-7-20 16:05



可以了,谢谢shi兄指教

TOP

返回列表