在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
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"中的第一个单词 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就被过滤掉了。 13. "\<…\>"这个表达式的作用这个表示精确查找一个字符串,\<sss 表示字的开始位置,sss\>表示字的结束位置 【补充】上文提到 . 作为元字符,可以用来匹配任意单个字符,比如:
可以匹配到: 但是在某些场景下,我们希望 . 作为一个普通的字符,比如匹配某个版本号:
可以在 . 前面加一个转义符号 \ 来实现这个效果,只匹配 2.1 这个版本号,过滤掉201、2a1等不符合要求的行。 扩展阅读:批处理常用符号详解 【实例补充】
删除所有以#开头,并且有且只有一个#的行: http://bbs.bathome.net/thread-59458-1-1.html
上面的问题如下 有个文件1.txt,内容是 要删除所有以#开头,并且有且只有一个#的行 处理后变成 应该用for 实现吗? @echo off findstr /bev "#[^#]*" a.txt pause @echo off for /f "delims= tokens=*" %%a in ('type "1.txt"^|findstr /b /e /v "#[^#]*"') do echo,%%a >>.\2.txt exit 到此这篇关于批处理FINDSTR正则表达式用法实例分析的文章就介绍到这了,更多相关批处理 FINDSTR用法内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论