批处理正则表达式(findstr)整理
语法
findstr [/b] [/e] [/l] [/r] [/s] [/i] [/x] [/v] [/n] [/m] [/o] [/p] [/offline] [/g:File] [/f:File] [/c:String] [/d:DirList] [/a:ColorAttribute] [Strings] [[Drive:][Path] FileName [...]]
参数
/b
如果位于⾏的开头则匹配模式。
/e
如果位于⾏的末尾则匹配模式。
/l
逐字地搜索字符串。
/r
使⽤搜索串作为正则表达式。Findstr 将所有元字符解释为正则表达式,除⾮使⽤了 /l。
/s
在当前⽬录和所有⼦⽬录中搜索匹配的⽂件。
/i
指定搜索不区分⼤⼩写。
/x
打印完全匹配的⾏。
/v
仅打印不包含匹配的⾏。
/n
在每个匹配的⾏之前打印⾏号。
/
m
如果⽂件包含匹配项,则仅打印该⽂件名。
/o
在每个匹配⾏之前打印查偏移量。
/p
跳过包含⾮可打印字符的⽂件。
/offline
利⽤脱机属性设置处理⽂件。
/f:File
从指定⽂件中读取⽂件列表。
/c:String
使⽤指定的⽂本作为⽂字搜索字符串。
/g:File
从指定⽂件得到搜索字符串。
/d:DirList
搜索以逗号分隔的⽬录列表。
/a:ColorAttribute
使⽤两个⼗六进制数指定颜⾊属性。
Strings
指定要在 FileName 中搜索的⽂本。
[ Drive:][Path] FileName [...]
指定要搜索的⽂件。
/
?
在命令提⽰符下显⽰帮助。
注释
• 使⽤ Strings 和 [Drive:][Path] FileName [...]
在命令字符串中,所有 findstr 命令⾏选项必须在 Strings 和 [Drive:][Path] FileName [...] 之前。
在 findstr 中使⽤正则表达式
Findstr 可以在任何 ASCII ⽂件或⽂件中精确查所要查的⽂本。然⽽,有时要匹配的信息只有⼀部分或要查更宽⼴的信息范围。在这种情况下,findstr 具有使⽤正则表达式搜索各种⽂本的强⼤功能。
正则表达式是⽤于指定⽂本类型的符号,与精确的字符串相反。标记使⽤⽂字字符和元字符。每个在常规的表达式语法中没有特殊意义的字符都是⽂字字符,与出现的该字符匹配。例如,字母和数字是⽂字符号。元字符是在正则表达式语法中具有特殊意义(操作符或分隔符)的符号。
下表列出 findstr 接受的元字符。
字符值
.
通配符:任何字符
*
重复:以前零次或多次出现的字符或类
^
⾏中的位置:⾏⾸
$
⾏中的位置:⾏尾
[class]
字符类:集中的任何⼀个字符
[^class]
反向类:⾮集中的任何⼀个字符
[X-y]
范围:指定范围内的任何字符
\X
转义:元字符 X 的⽂字⽤途
\ 字的位置:字⾸
xyz\>
字的位置:字尾
组合使⽤正则表达式语法的特殊字符功能⼗分强⼤。例如,下⾯的通配符 (.) 和重复符 (*) 的组合可以匹配任何字符串:
.*
将如下表达式⽤作匹配以“b”开头并以“ing”结尾的任意字符串的更⼤表达式的组成部分:
b.*ing
⽰例
使⽤空格分隔多个搜索字符串,除⾮参数以 /c 为前缀。要在⽂件 x.y 中搜索“hello”或“there”,请键⼊:
findstr "hello there" x.y
要在⽂件 x.y 中搜索“hello there”,请键⼊:
findstr /c:"hello there" x.y
若要查⽂件 中出现的所有单词“Windows”(⾸字母 W ⼤写),请键⼊:
findstr
若要搜索包含单词 Windows 的当前⽬录和所有⼦⽬录中的每个⽂件(不考虑字母⼤⼩写),请键⼊:
findstr /s /i Windows *.*
要查包含字“FOR”的所有⾏(前⾯可有任意空格,如:计算机程序中的循环),并包括每次出现的⾏号,请键⼊:
findstr /b /n /c:"*FOR" *.bas
如果要在相同组⽂件中搜索⼏个不同项⽬,请在新⾏上创建包含每个搜索标准的⽂本⽂件。也可以列出要在⽂本⽂件中搜索的确切⽂件。要使⽤⽂件 中的搜索标准来搜索 中列出的⽂件,然后将结果保存到⽂件 Results.out 中,请键⼊:
findstr / / > results.out
假设您想要查当前⽬录和所有⼦⽬录中包含单词“computer”的每个⽂件,⽽不考虑字母的⼤⼩写。若要列出包含单
js正则表达式验证数字和字母
词“computer”的所有⽂件,请键⼊:
findstr /s /i /m "\" *.*
现在假定不仅需要查单词“computer”,⽽且需要查以字母“comp”开头的所有其他单词,例如“compliment”和“compete”。请键⼊:
findstr /s /i /m "\
实例:
1.findstr .
< 或 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\>"这样就可以匹配了
=====================
到此这篇关于批处理正则表达式(findstr) 整理的⽂章就介绍到这了,更多相关批处理正则表达式内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!