zoukankan      html  css  js  c++  java
  • 正则单行和多行处理

    m 将待匹配串视为多行,^符号匹配字符串的起始或新的一行的起始;$符号匹配任意行的末尾。
    
    以下例只匹配第一行为a,否则无匹配;
    
    sh-3.2$ cat a6.pl 
    $line='a
    b
    c';
    if ($line =~ /^(.*)$/m){print $&."
    "};
    sh-3.2$ perl a6.pl 
    a
    
    当成多行处理,只能匹配到a
    
    $& ---匹配的内容
    
    
    s 将待匹配串视为单行。可以匹配
    
    
    sh-3.2$ cat a6.pl 
    $line='a
    b
    c';
    if ($line =~ /^(.*)$/s){print $&."
    "};
    sh-3.2$ perl a6.pl 
    a
    b
    c
    
    -----------------------------------------------------------------------------------------------------------
    
    /s  把多行当成单行处理
    
    sh-3.2$ cat a5.pl
    #!/usr/bin/perl   
    use strict;
    use DBI;
    my $dbName = 'orcl';  
    my $dbUser = 'test';  
    my $dbUserPass = 'test';  
    my $dbh = DBI->connect("dbi:Oracle:$dbName", $dbUser, $dbUserPass) or die "can't connect to database ";
    if ($#ARGV <0){
       print "请输入一个参数
    ";
      exit(-1);
    }
    my $var=$ARGV[0];
    my $sql = $var;
    
    if ($var =~ /selects+(.+)s+froms+.*/is){ $a = $1};
    chomp ($a);
    my @arr = (split /,/,"$a");
    foreach (@arr){
    chomp ($_);
    print $_." ";
    }
    my $sth = $dbh->prepare($sql); 
    $sth->execute();  
    while (my  @arr = $sth->fetchrow_array()){
    print "
    @arr
    ";
    }
    sh-3.2$ perl a5.pl "select a.session_id,
           a.sql_id,
           a.blocking_session,
           a.sample_time,
           a.module,
           a.PROGRAM,
           a.event,
           b.SQL_TEXT
      from v$active_session_history a, v$sqlarea b
     where a.sql_id = b.sql_id" | head -10 
    a.session_id 
           a.sql_id 
           a.blocking_session 
           a.sample_time 
           a.module 
           a.PROGRAM 
           a.event 
           b.SQL_TEXT
      
    1635 1bnt1kmfb8y30  05-JAN-15 11.38.04.823 AM SQL*Plus sqlplus@jhoa (TNS V1-V3)  select * from dba_objects order by 1,2,3,4,5

  • 相关阅读:
    Unable to load configuration.
    Hibernate映射文件如何配置触发器
    hibernate的集中持久化方法的区别
    Hibernate.lock()方法中各种锁的区别
    JNDI全面总结
    代理模式
    Java常见的几种内存溢出及解决方法
    Hibernate整合C3P0实现连接池
    Hibernate与Mybatis的概念区别
    sql之truncate 、delete与drop区别
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13351935.html
Copyright © 2011-2022 走看看