0

Web サイトのテーブルから Web サイト データをスクレイピングし、アプリで使用する 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>
4

3 に答える 3

1

dom 関数のみを使用するための簡単な例を次に示します。

$dom = new DOMDocument();
@$dom->loadHTMLFile(url);
$xpath = new DOMXPath($dom);

$xml = new DOMDocument();
foreach($xpath->query('//table/tr') as $tr) {
  $bulletin = $xml->appendChild($xml->createElement("bulletin"));
  $title = $xpath->query('.//td[2]//a', $tr)->item(0)->nodeValue;
  $bulletin->appendChild($xml->createElement("title",$title));
  $type = $xpath->query('.//td[3]/font', $tr)->item(0)->nodeValue;
  $bulletin->appendChild($xml->createElement("type",$type));
}
echo $xml->saveXML();
于 2012-06-06T00:40:23.533 に答える
1

主な問題は、HTML がそもそも無効であるため、この特定の HTML テーブルを解析しようとすると、ほとんどの PHP XML/HTML パーサーが失敗することです。PHP Simple HTML DOM Parserを使用して、テーブルを JSON に変換しました。このコードは、table.html に上で指定したテーブルのみが含まれていることを前提としています。

<?php
include 'simplehtmldom/simple_html_dom.php';

$html = file_get_html('table.html');

$row_count = 0;

foreach($html->find('tr') as $row) {
  $row_count++;
  foreach($html->find('td') as $cell) {
    $cell_text = $cell->plaintext;
    // There are no CSS classes or IDs to differentiate between columns in the
    // table, so we're using the width instead
    switch ($cell->attr['width']) {
      case '58%':
        $bulletins[$row_count]['title'] = $cell_text;
        break;
      case '17%':
        $bulletins[$row_count]['type'] = $cell_text;
        break;
    }
    $bulletins[$row_count]['id'] = $row_count;
  }
}

// Remove the invalid </a> tags from the cell text, and convert to JSON
$json = str_replace('<\/a>', '', json_encode($bulletins));

// Output:
// {"1":{"id":1,"title":"Another News","type":"Updates"},"2":{"id":2,"title":"Another     News","type":"Updates"}}
echo $json;

?>
于 2012-06-05T17:51:29.400 に答える