如果未传递数组,则为regex文件

时间:2016-02-19 17:31:45

标签: php json regex

我有一个这种结构的文件:

[19-02-2016 16:57:17.104504] [info] system done. 
 0: array(
   'ID' => 'john foo'
 )

[19-02-2016 16:57:17.110482] [info] transaction done. 
   0: array(
      'ID' => 'john foo'
   )

现在我想将文件内容解析为json,实际上一切运行良好:

<?php
$file = 'test.log';

$content = array(); 
$content["trace"] = array();
$input = file_get_contents('test.log');

preg_match_all('/\[(.*)\][\s]*?\[(.*?)\][\s]*?(.*)[\s][^\']*\'ID\'[ ]*=>[ ]*\'(.*)\'/', $input, $regs, PREG_PATTERN_ORDER);
for ($i = 0; $i < count($regs[0]); $i++) {
    $content['trace'][] = array(
        'date'    => $regs[1][$i],
        'type'    => trim($regs[2][$i]),
        'message' => trim($regs[3][$i]),
        'ID'      => trim($regs[4][$i]),
    );
}

// return $content;
echo '<pre>'; print_r($content); echo '</pre>';  // For testing only
$content = json_encode($content);                // For testing only
echo '<pre>' . $content . '</pre>';              // For testing only

现在这段代码返回了这个结果:

{
"trace":[
    {
        "date":"19-02-2016 16:57:17.104504",
        "type":"info",
        "message":"system done.",
        "ID":"john foo"
    },
    {
        "date":"19-02-2016 16:57:17.110482",
        "type":"info",
        "message":"transaction done.",
        "ID":"john foo"
    }
]

}

问题是,如果我有这种情况(在文件中):

[19-02-2016 16:57:17.104504] [info] system done. 

[19-02-2016 16:57:17.110482] [info] transaction done. 
   0: array(
      'ID' => 'john foo'
   )

我得不到结果'因为正则表达式失败。这是'因为第一行没有任何数组,我怎么能解决这种情况?

CODEHART代码:

preg_match_all('\[(.*)\][\s]*?\[(.*?)\][\s]*?(.*)[\s.]([^\']*\'ID\'[ ]*=>[ ]*\'(.*)\')?', $fh, $regs, PREG_PATTERN_ORDER);

        for($i = 0; $i < count($regs[0]); $i++)
        {
            var_dump($regs);
            $content['trace'][] = array(
                'date'    => $regs[1][$i],
                'type'    => trim($regs[2][$i]),
                'message' => trim($regs[3][$i]),
                'ID'      => trim($regs[4][$i]),
            );
        }

我从var_dump

获得null

1 个答案:

答案 0 :(得分:2)

更新:php代码

  preg_match_all('/\[(.*)\][\s]*?\[(.*?)\][\s]*?(.*)[\s.]+(?:\d+[^\']*\'ID\'[ ]*=>[ ]*\'(.*)\')?/', $input, $regs, PREG_PATTERN_ORDER);

编辑:添加字符串的array部分是可选的,并注意\d,假设数组行总是以数字开头,因此它与正如@dillinger指出的那样,日志中的下一行也是如此。