辉克's Blog

创造机会的人是勇者;等待机会的人是愚者

批处理命令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.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\>”这样就可以匹配了

 

字符
. 通配符:任何字符
* 重复:以前字符或类的零次或多次出现
^ 行位置:行的开始
$ 行位置:行的结尾
[class] 字符类:集合中任何一个字符
[^class] 反类:不在集合中的任何一个字符
[x-y 范围:范围:指定范围内的任何字符
\x 取消:元字符 x 的文字用途
\<xyz 字位置:字首
xyz> 字位置:字尾

 

MS-DOS命令范例

用空格分隔多个搜索字符串,除非参数以 /c 为前缀。要在文件 x.y中搜索“hello”或“there”,请键入:

findstr “hello there” x.y

要在文件 x.y中搜索“hello there”,请键入:

findstr /c:”hello there” x.y

要查找文件 Proposal.txt中出现的所有单词“Windows”(首字母 W 大写),请键入:

findstr Windows proposal.txt

要搜索包含单词 Windows 的当前目录和所有子目录中的每个文件,不考虑字母大小写,请键入如下命令:

findstr /s /i Windows *.*

要查找包含字“FOR”的所有行(前面可有任意数量的空格,如:计算机程序中的循环),并包括每次出现的行号,请键入:

findstr /b /n /c:”*FOR” *.bas

如果要在相同组文件中搜索几个不同项目,请创建在新行上包含每个搜索标准的文本文件。也可以列出要在文本文件中搜索的确切文件。要使用文件 Finddata.txt中的搜索条件,请搜索 Filelist.txt中列出的文件,然后将结果保存到文件 Results.out中,请键入:

findstr /g:finddata.txt /f:filelist.txt > results.out

假设您想要找到当前目录和所有子目录中每个包含“computer”这个单词的文件,而不考虑字母的大小写。要列出包含单词“computer”的所有文件,请键入:

findstr /s /i /m “\<computer\>” *.*

现在假定不仅需要查找字“computer”,而且需要查找以字母“comp”开头的所有其他字,例如“compliment”和“compete”。请键入:

findstr /s /i /m “\<comp.*” *.*

发表评论

电子邮件地址不会被公开。 必填项已用*标注