使用preg_match_all用PHP解析html表

时间:2012-12-13 01:45:53

标签: php

我使用以下PHP脚本来解析表。

如果每个元素位于同一行,则它可以工作,例如:

<td></td>
<td></td>
<td></td>

如果“开始标记”和“关闭标记”位于不同的行上,我该如何使其工作?像这样:

<td></td>
<td>
</td>
<td></td>

PHP脚本:

function parseTable($html)
{
  // Find the table
  preg_match("/<table.*?>.*?<\/[\s]*table>/s", $html, $table_html);

  // Get title for each row
  preg_match_all("/<th.*?>(.*?)<\/[\s]*th>/", $table_html[0], $matches);
  $row_headers = $matches[1];

  // Iterate each row
  preg_match_all("/<tr.*?>(.*?)<\/[\s]*tr>/s", $table_html[0], $matches);

  $table = array();

  foreach($matches[1] as $row_html)
  {
    preg_match_all("/<td.*?>(.*?)<\/[\s]*td>/", $row_html, $td_matches);
    $row = array();
    for($i=0; $i<count($td_matches[1]); $i++)
    {
      $td = strip_tags(html_entity_decode($td_matches[1][$i]));
      $row[$row_headers[$i]] = $td;
    }

    if(count($row) > 0)
      $table[] = $row;
  }
  return $table;
}

1 个答案:

答案 0 :(得分:2)

Preg_match不会解析HTML,因为它不是正则表达式。最好的解决方案是使用一个
XML Parser - PHP Doc

每个工具都有问题需要解决,解析不是preg_match的一个