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