返回列表 发帖

[转贴] 批处理命令findstr正则表达式的基本用法

由联盟论坛9527整理
1.findstr . 2.txt 或 Findstr "." 2.txt  
从文件2.txt中查找任意字符,不包括空字符或空行
====================
2.findstr .* 2.txt 或 findstr ".*" 2.txt
从文件2.txt中查找任意字符包括空行和空字符
====================
3.findstr "[0-9]" 2.txt
从文件2.txt中查找包括数字09的字符串或行
====================
4.findstr "[a-zA-Z]" 2.txt
从文件2.txt中查找包括任意字符的字符串或行
====================
5.findstr "[abcezy]" 2.txt
从文件2.txt中查找包括a b c e z y字母的字符串或行
====================
6.findstr "[a-fl-z]" 2.txt
从文件2.txt中查找小写字符a-f l-z的字符串,但不包含g h I j k这几个字母。
====================
7.findstr "M[abc][hig]Y" 2.txt
从文件2.txt中可以匹配 MahY , MbiY, MahY等…..
====================
8. ^和$符号的应用
^ 表示行首,"^step"仅匹配 "step hello world"中的第一个单词
$ 表示行尾,"step$"仅匹配 "hello world step"中最后一个单词
====================
9.findstr "[^0-9]" 2.txt
如果是纯数字的字符串或者行便过滤掉,例如2323423423 这样的字符串,如果是345hh888这样的形式就不成了。
====================
10.findstr "[^a-z]" 2.txt
同上,如果是纯字母的字符串或者行便过滤掉,例如 sdlfjlkjlksjdklfjlskdf这样的字符,如果是sdfksjdkf99999这样的形式,掺杂着数字就不成了
====================
11.*号的作用
前面已经说过了 ".*"表示搜索的条件是任意字符,*号在正则表达式中的作用不是任何字符,而是表示左侧字符或者表达式的重复次数,*号表示重复的次数为零次或者多次。
====================
12.findstr "^[0-9]*$" 2.txt
这个是匹配找到的纯数字,例如 234234234234,如果是2133234kkjl234就被过滤掉了。
   Findstr "^[a-z]*$" 2.txt
这个是匹配找到的纯字母,例如 sdfsdfsdfsdf,如果是213sldjfkljsdlk就被过滤掉了
如果在搜索条件里没有*号,也就是说不重复左侧的搜索条件,也就是[0-9] [a-z]那只能匹配字符串的第一个字符也只有这一个字符,因为有行首和行尾的限制,"^[0-9]$"第一个字符如果是数字就匹配,如果不是就过滤掉,如果字符串是 9 就匹配,如果是98或者9j之类的就不可以了。
=====================
13. "\<…\>"这个表达式的作用
这个表示精确查找一个字符串,\<sss 表示字的开始位置,sss\>表示字的结束位置
echo hello world computer|findstr "\<computer\>"这样的形式
echo hello worldcomputer|findstr "\<computer\>" 这样的形式就不成了,他要找的是 "computer"这个字符串,所以不可以。
echo hello worldcomputer|findstr ".*computer\>"这样就可以匹配了COPY
【补充】
上文提到 . 作为元字符,可以用来匹配任意单个字符,比如:
findstr "2.1" test.txtCOPY
可以匹配到:
2.1
201
2a1
等等,包含这些字符串的行。

但是在某些场景下,我们希望 . 作为一个普通的字符,比如匹配某个版本号:
findstr "2\.1" test.txtCOPY
可以在 . 前面加一个转义符号 \ 来实现这个效果,只匹配 2.1 这个版本号,过滤掉201、2a1等不符合要求的行。

扩展阅读:批处理常用符号详解
http://bbs.bathome.net/thread-1205-1-1.html#pid25363

【实例补充】
匹配以张三李四开头的行:
findstr "^张三 ^李四" "1.txt" > "2.txt"COPY
删除所有以#开头,并且有且只有一个#的行:
http://bbs.bathome.net/thread-59458-1-1.html
findstr /b /e /v "#[^#]*" 1.txtCOPY
3

评分人数

多年以后拜读了一下,讲的非常好,要是带各种参数的也能讲一下就好了

TOP

回复 1# youxi01
使用$匹配行尾,测试不成功!

TOP

回复 45# qixiaobin0715
楼上多此一举,这样写本身就不区分大小写,就不需要参数/i了。这样即可:
4条也可这样:findstr "[a-z]" 2.txtCOPY

TOP

楼主的第4条也可这样:findstr /i [a-z] 2.txt

TOP

回复 1# youxi01


    好,学习了,感谢

TOP

回复 1# youxi01
很好例子,受益匪浅。但第12条有个小小的问题,既然*号表示0到若干次重复前面的字符,某行不存在任何字符也能匹配,所以空行也能匹配。应当修改为:
findstr "^[0-9][0-9]*$"和findstr "^[a-z][a-z]*$"
这样就比较严谨了。

TOP

不知道批处理findstr能否支持贪婪匹配和惰性匹配不。。。。   还有很多正则表达式的字符能支持不。


对翻译微软的文档有点蛋疼。一般表达式听着就很别扭

TOP

@echo off
color 0a
for /f %%a in ('type %cd%\file\c.txt^|findstr "\<.inf\>"') do (echo %%a >>%cd%\findstr.inf.txt)
pause

为什么这样运行没有结果,换成".inf$"也是一样,连文本也没有生成。
但是如果用".inf\>"的话运行就完全正常,里面找出一堆含有inf的行。
是不是在windows10里"\<.inf\>"和".inf$"这两个功能没有了????

TOP

如何实现执行bat文件后,生成的和所在的文件夹名字相同的CSV文件。

TOP

findstr这个命令字符串查找很强大,支持一部分正则表达式

TOP

谢楼主的分享!支持...

TOP

这个语句返回的是什么?

TOP

刚好在找这方面的资料,多谢了

TOP

回复 34# fluent


    findstr命令不支持这种高级正则

TOP

返回列表