相关文章推荐
低调的核桃  ·  弹簧反应安全性: ...·  12 月前    · 
低调的饭盒  ·  Sql Server ...·  2 年前    · 
叛逆的橡皮擦  ·  Day 27. ...·  2 年前    · 
日志文件:[2018-07-2407:03:57]SessionId[无序字符串1][INFO][无序字符串4]无序字符串7[2018-07-2407:03:58]SessionId[无序字符串2][INFO][无序字符串5]无序字符串8[2018-07-2407:03... 日志文件:
[2018-07-24 07:03:57] SessionId[无序字符串1][INFO][无序字符串4]无序字符串7
[2018-07-24 07:03:58] SessionId[无序字符串2][INFO][无序字符串5]无序字符串8
[2018-07-24 07:03:58] SessionId[无序字符串3][INFO][无序字符串6]无序字符串9
获取为$log,正则匹配到换行结束
preg_match_all("/\[(.*)\] SessionId\[(.*)\]\[INFO\]\[(.*)\]([^\r\n]*)/U",$log,$out)
print_r($out);
无法识别其中后面的“无序字符串7\8\9”,求助。

preg_match_all函数可能匹配[^\r\n]可能有问题,我给替换成点,就可以了.点也代表除换行符外的所有字符.另外,为使.*能够找到行尾,我给正则表达式改成了多行形式.

完整的PHP程序如下

<?php
 $log="[2018-07-24 07:03:57] SessionId[无序字符串1][INFO][无序字符串4]无序字符串7\r\n[2018-07-24 07:03:58] SessionId[无序字符串2][INFO][无序字符串5]无序字符串8\r\n[2018-07-24 07:03:58] SessionId[无序字符串3][INFO][无序字符串6]无序字符串9\r\n";
 $regex="/^\[(.*)\] SessionId\[(.*)\]\[INFO\]\[(.*)\](.*)$/mU";
 preg_match_all($regex,$log,$out);
  print_r($out);
?>


运行结果
Array
(
    [0] => Array
        (
            [0] => [2018-07-24 07:03:57] SessionId[无序字符串1][INFO][无序字符串4]无序字符串7
            [1] => [2018-07-24 07:03:58] SessionId[无序字符串2][INFO][无序字符串5]无序字符串8
            [2] => [2018-07-24 07:03:58] SessionId[无序字符串3][INFO][无序字符串6]无序字符串9
        )

    [1] => Array
        (
            [0] => 2018-07-24 07:03:57
            [1] => 2018-07-24 07:03:58
            [2] => 2018-07-24 07:03:58
        )

    [2] => Array
        (
            [0] => 无序字符串1
            [1] => 无序字符串2
            [2] => 无序字符串3
        )

    [3] => Array
        (
            [0] => 无序字符串4
            [1] => 无序字符串5
            [2] => 无序字符串6
        )

    [4] => Array
        (
            [0] => 无序字符串7
            [1] => 无序字符串8
            [2] => 无序字符串9
        )

)