只是想知道这将如何完成。假设在外部网站上有一个简单的 HTML 表,并且您有一个与该 HTML 表具有相同结构的数据库。我知道您可以使用它file_get_contents
来抓取整个网页。
从那里,我假设您将从标签中删除file_get_contents
除标签之间的内容之外的所有内容<table></table>
,从而隔离包含您要写入的数据的表。
你下一步怎么做?假设您的数据库表结构与 HTML 表的结构相匹配,那么将表数据写入数据库的最简单方法是什么?
只是想知道这将如何完成。假设在外部网站上有一个简单的 HTML 表,并且您有一个与该 HTML 表具有相同结构的数据库。我知道您可以使用它file_get_contents
来抓取整个网页。
从那里,我假设您将从标签中删除file_get_contents
除标签之间的内容之外的所有内容<table></table>
,从而隔离包含您要写入的数据的表。
你下一步怎么做?假设您的数据库表结构与 HTML 表的结构相匹配,那么将表数据写入数据库的最简单方法是什么?
也许这会很有趣(希望如此,哈哈),一个解析 html 的超级简单的类。
仅使用 DOMDocument 和 cURL
<?php
$scraper = new DOMScraper();
//example couldent think of a site with an example table
$scraper->setSite('http://cherone.co.uk/forum')->setSource();
//all tables on page
echo '<table>'.$scraper->getInnerHTML('table').'</table>';
//get only tables with id="some_table_id" or any attribute match eg class="somthing"
echo '<table>'.$scraper->getInnerHTML('table','id=some_table_id').'</table>';
//get all tables contents but return only nodeValue/text
echo '<table>'.$scraper->getInnerHTML('table','id=some_table_id',true).'</table>';
/**
* Generic DOM scapper using DOMDocument and cURL
*/
Class DOMScraper extends DOMDocument{
public $site;
private $source;
private $dom;
function __construct(){
libxml_use_internal_errors(true);
$this->preserveWhiteSpace = false;
$this->strictErrorChecking = false;
}
function setSite($site){
$this->site = $site;
return $this;
}
function setSource(){
if(empty($this->site))return 'Error: Missing $this->site, use setSite() first';
$this->source = $this->get_data($this->site);
return $this;
}
function getInnerHTML($tag, $id=null, $nodeValue = false){
if(empty($this->site))return 'Error: Missing $this->source, use setSource() first';
$this->loadHTML($this->source);
$tmp = $this->getElementsByTagName($tag);
$ret = null;
foreach ($tmp as $v){
if($id !== null){
$attr = explode('=',$id);
if($v->getAttribute($attr[0])==$attr[1]){
if($nodeValue == true){
$ret .= trim($v->nodeValue);
}else{
$ret .= $this->innerHTML($v);
}
}
}else{
if($nodeValue == true){
$ret .= trim($v->nodeValue);
}else{
$ret .= $this->innerHTML($v);
}
}
}
return $ret;
}
function innerHTML($dom){
$ret = "";
$nodes = $dom->childNodes;
foreach($nodes as $v){
$tmp = new DOMDocument();
$tmp->appendChild($tmp->importNode($v, true));
$ret .= trim($tmp->saveHTML());
}
return $ret;
}
function get_data($url){
if(function_exists('curl_init')){
$ch = curl_init();
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 5);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$data = curl_exec($ch);
curl_close($ch);
return $data;
}else{
return file_get_contents($url);
}
}
}
?>
例如,您可以使用PHP Simple HTML DOM Parser