zoukankan      html  css  js  c++  java
  • perl 正则捕获 /(?d+(?:.d+)?)s+/

    2.3.2 grok 正则捕获:
    
    s+ 和 [
    	
    f]+ 一样  
    
    
    1、命名分组格式为(?<grp name>),反向引用时用k<grp name>
    
    2、命名分组的匹配的结果存在在变量%+变量中,取命名分组值,$+{grp name}.
    
    
    2.3.2 grok 正则捕获
    
    
    1、命名分组格式为(?<grp name>),反向引用时用k<grp name>
    
    2、命名分组的匹配的结果存在在变量%+变量中,取命名分组值,$+{grp name}.
    
    [elk@db01 logstash]$ cat a1.pl 
    my $str="  begin 123.456 end  ";
    if ($str =~/(?<request_time>d+.d+)/)
       {
        my ($request_time) = ($+{request_time});  
       print $request_time."
    ";};
    
    [elk@db01 logstash]$ perl a1.pl 
    123.456
    
    
    ? 表示0次或者一次
    
    (pattern)  
     匹配 pattern 并获取这一匹配。所获取的匹配可以从产生的 Matches 集合得到,在VBScript 中使用 SubMatches 集合,在JScript 中则使用 $0…$9 属性。要匹配圆括号字符,请使用 ‘′或‘’。  
       
    (?:pattern)  
     匹 配 pattern 但不获取匹配结果,也就是说这是一个非获取匹配,不进行存储供以后使用。这在使用 “或” 字符 (|) 来组合一个模式的各个部分是很有用。例如, ‘industr(?:y|ies) 就是一个比 ‘industry|industries’ 更简略的表达式。  
       
    (?=pattern)  
     正 向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如,‘Windows (?=95|98|NT|2000)’ 能匹配 “Windows 2000〃 中的 “Windows” ,但不能匹配 “Windows 3.1〃 中的 “Windows”。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始。  
       
    (?!pattern)  
     负 向预查,在任何不匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如‘Windows (?!95|98|NT|2000)’ 能匹配 “Windows 3.1〃 中的 “Windows”,但不能匹配 “Windows 2000〃 中的 “Windows”。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始   
      
    在PERL的模式中,括号内的子模式将存贮在内存中,此功能即取消存贮该括号内的匹配内容,如/(?:a|b|c)(d|e)f1/中的1表示已匹配的d或e,而不是a或b或c 
    
    
    
    
    (?:) 意思是匹配结果不当作分组,不会记录到$1,$2,$3中
    
    
    [elk@db01 logstash]$ cat a1.pl 
    my $str="  begin 123.456 end  ";
    if ($str =~/(?<request_time>d+(?:.d+)?)s+/)
       {
        my ($request_time) = ($+{request_time});  
       print $request_time."
    ";};
    [elk@db01 logstash]$ perl a1.pl 
    123.456
    
    (?:.d+)  对捕获的 不记录到$1,$2,$3中
    
    
    
    [elk@db01 logstash]$ cat a1.pl 
    my $str="  begin 123 end  ";
    if ($str =~/(?<request_time>d+(?:.d+)?)s+/)
       {
        my ($request_time) = ($+{request_time});  
       print $request_time."
    ";};
    [elk@db01 logstash]$ perl a1.pl 
    123
    
    
    
    

  • 相关阅读:
    AngularJS学习之旅—AngularJS 服务(八)
    Svchost进程和共享服务病毒原理
    服务劫持
    利用BHO实现浏览器劫持
    动态反调试
    常用的静态反调试技术及其规避方法
    teb, peb,seh 结构
    线程本地存储tls
    注入技术总结
    注入技术--远程线程注入
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13349934.html
Copyright © 2011-2022 走看看