dos命令中findstr正则用法实例详解

发布时间:2019-08-28编辑:脚本学堂
本文介绍下,在dos或批处理下findstr的正则用法,用于在批处理中实现文本搜索或替换,还是能派上大用场的。有需要的朋友参考下吧。

本文分享findstr命令中,使用正则的一些例子,供大家学习参考。

例子:
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中查找包括数字0-9的字符串或行

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.

复制代码 代码示例:
finstr "[^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>" 如此,可以匹配。