批处理命令findstr正则表达式的基本用法
由联盟论坛9527整理[code]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\>"这样就可以匹配了[/code]【补充】
上文提到 . 作为元字符,可以用来匹配任意单个字符,比如:[code]findstr "2.1" test.txt[/code]可以匹配到:
2.1
201
2a1
等等,包含这些字符串的行。
但是在某些场景下,我们希望 . 作为一个普通的字符,比如匹配某个版本号:[code]findstr "2\.1" test.txt[/code]可以在 . 前面加一个转义符号 \ 来实现这个效果,只匹配 2.1 这个版本号,过滤掉201、2a1等不符合要求的行。
扩展阅读:批处理常用符号详解
[url]http://bbs.bathome.net/thread-1205-1-1.html#pid25363[/url]
【实例补充】
匹配以[color=Blue]张三[/color]或[color=Blue]李四[/color]开头的行:[code]findstr "^张三 ^李四" "1.txt" > "2.txt"[/code]删除所有以#开头,并且有且只有一个#的行:
[url]http://bbs.bathome.net/thread-59458-1-1.html[/url][code]findstr /b /e /v "#[^#]*" 1.txt[/code] 呵呵``这个倒是有点用处..........收获了一点点..
看不太懂
:( 现在回来看就好多了呵呵
感觉进步了
这个findstr用处很广啊
哪天搜集下这方面的资料 这个站点是后起之秀,很多老的批处理站点,都是转载一些特别深奥的,一般人看不懂的东西,并且都是没有解释的,强烈支持本站点 支持,看不太懂,但是学习了! <P>不错啊,原来bat还有正则表达式啊,长知识了,顶一下。呵呵。受益匪浅,建议不懂正则表达式的可以先学习一下js的正则表达式,然后再看这个应该比较容易理解。</P>
js的正则表达式和这一样吗
感觉好像还是有差别的 我在a.txt中输入一个字符1,然后不回车换行。保存。用findstr "^[0-9]*$"就搜不到这个1。
如果在字符1后回车换行,就能搜到这个1。
请问是怎么回事? 这个没示例代码,* 用法比较难以理解,建议那位版主做个 示例代码。就像变量截取点点通 的那个很不错。 不错,就是说的有点不太明确,希望可以改进
回复 11楼 的帖子
哪里不明确?你希望哪里得到改进? 管理员:9.finstr "[^0-9]" 2.txt
改下,呵呵^_^
回复 13楼 的帖子
我帮楼主修改了,可能是9527兄在CN-DOS发帖时就有这个笔误,呵呵。 好像find都没什么用了哦,,回复 15楼 的帖子
统计文本行数的时候,用find命令更加简洁。 这个看来还真是有些不懂,基础比较差 支持一下,看了还要回运用 谢谢. 基础的东西太重要了.精品. 这两个命令为什么都可以输出空格?[code]1.findstr . 2.txt 或 Findstr "." 2.txt从文件2.txt中查找任意字符,不包括空字符或空行
====================
2.findstr .* 2.txt 或 findstr ".*" 2.txt
从文件2.txt中查找任意字符包括空行和空字符
====================[/code] 完全看懂呢,真是对亏群里的朋友帮忙
回复 20楼 的帖子
因为空格也属于“任意字符” 这个东西真好啊!谢谢楼主 这个看过N回了,不过很少用,见人家用得很好的!~
问一个:
怎么查找非数字和字母的?——从另外角度说查找汉字? 懂了一半,再好好参详 学习了,很不错哦 [code]// test2.txt
ABCDEFG
abcdefg
E:\tmp>findstr "[a-z]" test2.txt
ABCDEFG
abcdefg
E:\tmp>findstr "[A-Z]" test2.txt
ABCDEFG
abcdefg[/code]findstr "[a-z]" test2.txt 我的理解是搜索包含任意小写英文字母的行,但是为什么搜索出来全是大写的行也输出结果呢?谢谢! 总觉的findstr比find要好用,有时用find总查不出来,findstr却能查出来,不知道什么原因 [b]回复 [url=http://www.bathome.net/redirect.php?goto=findpost&pid=101797&ptid=24]27#[/url] [i]几维kiwi[/i] [/b]
参照 /I [b]回复 [url=http://www.bathome.net/redirect.php?goto=findpost&pid=137940&ptid=24]28#[/url] [i]wangx[/i] [/b]
findstr支持正则,find不支持。
页:
[1]
2