• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    批处理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\&;"这样就可以匹配了

    【补充】

    上文提到 . 作为元字符,可以用来匹配任意单个字符,比如:

    findstr "2.1" test.txt

    可以匹配到:
    2.1
    201
    2a1
    等等,包含这些字符串的行。

    但是在某些场景下,我们希望 . 作为一个普通的字符,比如匹配某个版本号:

    findstr "2\.1" test.txt

    可以在 . 前面加一个转义符号 \ 来实现这个效果,只匹配 2.1 这个版本号,过滤掉201、2a1等不符合要求的行。

    扩展阅读:批处理常用符号详解

    【实例补充】
    匹配以张三或李四开头的行:

    findstr "^张三 ^李四" "1.txt" > "2.txt"

    删除所有以#开头,并且有且只有一个#的行:

    http://bbs.bathome.net/thread-59458-1-1.html

    findstr /b /e /v "#[^#]*" 1.txt

    上面的问题如下

    有个文件1.txt,内容是
    12
    123#
    #123
    ##12
    #12#34#
    # aaaa
    #
    ####

    要删除所有以#开头,并且有且只有一个#的行

    处理后变成
    12
    123#
    ##12
    #12#34#
    ####

    应该用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用法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • 批处理 正则表达式(findstr) 整理
    上一篇:批处理 Autorun 病毒清除工具
    下一篇:for命令的一些bug分析
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    批处理FINDSTR正则表达式用法实例分析 批处理,FINDSTR,正则,表达式,