如何使用 php 在 html 表中显示日志文件数据?

我想使用 php 以 html 表格形式显示我的日志文件数据。我的日志文件数据看起来像

2019-08-01 07:45:13 112.196.23.170 Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:68.0) Gecko/20100101 Firefox/68.0 42112452 并且用户点击了这封电子邮件:mike@jvpsus.com India IN Punjab

我想在表格行中显示2019-08-01 07:45:13

然后是第二行的112.196.23.170

然后显示整个Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:68.0) Gecko/20100101 Firefox/68.0

然后 id 42112452第 4 行

然后第六行和用户点击了这封电子邮件:mike@jvpsus.com

最后第七排印度旁遮普邦

每当我试图获取数组中的数据时,在 foreach 数组分解为键和值之后。我试图用空间爆炸 (' ', $string)。但是整个句子字符与空间进入单独的数组索引。

当我尝试 foreach 时,它给了我这个输出

http://img2.mukewang.com/61ee35a20001d16f02120373.jpg

我想要的输出如下

http://img.mukewang.com/61ee35b100019bff04510157.jpg

这是我的代码



$logFile = 'testlog.log';

$lines = file($logFile); // Get each line of the file and store it as an array


// echo "<pre>";

// print_r($lines);


foreach($lines as $line)

{

    // list($date, $time, $ip, $domain,$no,$mail,$cnt, $cod, $state) = explode(' ', $line);

    $output = preg_replace('!\s+!', ' ', $line);

     echo "<pre>";

    print_r (explode(" ",$output));




}



?>```



守着星空守着你
浏览 160回答 2
2回答

当年话下

提醒您:尝试以 csv 格式登录可能更容易解析日志行。但如果不可能,那么:更改您的正则表达式。并将其移出foreach循环。如果你想让它成为一个表格,请使用<table>,&nbsp;<tr>,<td>标签。如果将其更改为 AJAX API 会更好:通过 JSON 返回拆分数据。并在前端渲染。尝试完成以下代码。$logFile = 'testlog.log';$lines = file($logFile); // Get each line of the file and store it as an array// The regular expression to break lines$rgx = '/(\d+-\d+-\d+) (\d+:\d+:\d+) (\d+\.\d+\.\d+\.\d+) (.*? \(.*\)) (.*? .*?) (\d*) (.* email: .*@.*?) (.*$)/';echo "<table>\n";foreach($lines as $line) {&nbsp; &nbsp; echo "<tr>\n";&nbsp; &nbsp; $output = preg_split($rgx, $line);&nbsp; &nbsp; ...&nbsp; &nbsp; echo "<td>$output[0]</td>\n"&nbsp; &nbsp; ...&nbsp; &nbsp; echo "</tr>\n";}echo "</table>\n";

ibeautiful

制表符作为特殊符号可能有效
打开App,查看更多内容
随时随地看视频慕课网APP