我需要从网站上的表格中抓取一些网站数据,并创建一个将由应用程序使用的 XML 或 JSON 文档。我在获取以下数据时遇到了一些问题。
该表如下所示:
<table border="0" cellpadding="3" cellspacing="0" bgcolor="#DDEEFF" width="100%">
<tr>
<td width="20%" ><font face="Verdana, Arial" size="1">SRC</a></td></font>
<td width="58%" ><font face="Verdana, Arial" size="1"><a href="http://example.com/this/news?id=1&by=today" onMouseOver="a('Open Bulletin');return true" onMouseOut="b()">Welcome</font></a></td>
<td width="17%" align="center"><font face="Verdana, Arial" size="1">Event</td></font>
</tr>
<tr>
<td width="20%" ><font face="Verdana, Arial" size="1">FMD</a></td></font>
<td width="58%" ><font face="Verdana, Arial" size="1"><a href="http://example.com/this/news?id=2&by=today" onMouseOver="a('Open Bulletin');return true" onMouseOut="b()">Another News</font></a></td>
<td width="17%" align="center"><font face="Verdana, Arial" size="1">Updates</td></font>
</tr>
</td>
我想创建一个如下所示的 XML 提要或 JSON:
<bulletins>
<title>Welcome</title>
<id>1</id>
<type>News</type>
</bulletins>
<bulletins>
<title>Another News</title>
<id>2</id>
<type>Updates</type>
</bulletins>
这是我当前的代码:
<?php
$body = explode('<table border="0" cellpadding="3" cellspacing="0" bgcolor="#DDEEFF" width="100%">', $html);
$xml = simplexml_load_string("<?xml version='1.0' encoding='utf-8'?><xml />");
$rows = array();
foreach (array_slice(explode('<tr>', end($body)), 1) as $row)
{
preg_match('#<a.*?href="(.*?)".*?>(.*?)</a>#i', $row, $title);
preg_match('/<a.*href="(.*)".*>(.*)<\/a>/iU', $row, $id);
// preg_match('/type">([^<]+)<\/td>/', $row, $type);
$node = $xml->addChild('bulletins');
$node->addChild('title', $title[1]);
$node->addChild('id', $id[1]);
// $node->addChild('type', $due[1]);
}
header('Content-Type: text/xml');
echo $xml->asXML();
?>
但是我得到了这个问题
<xml>
<bulletins>
<title>http://example.com/this/news?id=1</title>
<id>http://example.com/this/news?id=1</id>
</bulletins>
<bulletins>
<title>http://example.com/this/news?id=2</title>
<id>http://example.com/this/news?id=2</id>
</bulletins>
</xml>