如何从 simpleXML_Element_Object 中抓取内容?

问题描述 投票:0回答:2

我正在尝试从任何维基页面右侧的维基百科信息框中抓取内容。

我正在使用 DOMXpath 来抓取内容。

this 链接的信息框(位于右侧)上,我正在尝试抓取

Traded as
部分。然而,在页面源代码中,它是由多个 href 组成的。

Traded as:  NASDAQ: GOOG
            NASDAQ-100 Component
            S&P 500 Component

我的 SIMPLE_XML_Element_Object 看起来像这样

SimpleXMLElement object {
 @attributes => array(1) (
[class] => (string)
)
 th => SimpleXMLElement object {
@attributes => array(2) (
  [scope] => (string) row
  [style] => (string) text-align:left;
)
a => (string) Traded as
}
td => SimpleXMLElement object {
@attributes => array(2) (
  [class] => (string)
  [style] => (string)
)
a => array(4) (
  [0] => (string) NASDAQ
  [1] => (string) GOOG
  [2] => (string) NASDAQ-100 Component
  [3] => (string) S&P 500 Component
)
}

这就是我试图抓取的内容。

foreach ($xmlElements->xpath("//div[@id='mw-content-text']/table[@class='infobox vcard']/tr") as $node) 
{
   $name = (string)$node->th;
   if(empty($name))
     $name = (string)$node->th->a;
   if(is_array($node->td->a))
       $value = implode('~', (string) $node->td->a);
    else
       $value = (string) $node->td->a;
}

但是我无法获得

"NASDAQ: GOOD ~ NASDAQ-100 Component ~ NASDAQ-100 Component"
形式的值,并且我单独获得
"NASDAQ"
形式的值,这不是必需的。

如果节点是数组,如何获取节点的值?

希望我的问题很清楚。任何帮助将不胜感激。

php web-scraping dom xpath
2个回答
1
投票

请参阅http://www.laprbass.com/RAY_temp_user1518659.php

输出:string(64)“纳斯达克:GOOG ~ NASDAQ-100 成分股 ~ S&P 500 成分股”

如果您只使用本机 PHP 函数,这确实更容易实现!

<?php // RAY_temp_user1518659.php
error_reporting(E_ALL);
echo '<pre>';

// ACQUIRE THE DOCUMENT
$url = 'http://en.wikipedia.org/wiki/Google';
$htm = file_get_contents($url);

// ACTIVATE THIS TO SEE THE ENTIRE DOCUMENT
// echo htmlentities($htm);

// ISOLATE THE "TRADED AS" PART
$sig = 'Traded as';
$arr = explode($sig, $htm);
$htm = $arr[1];
$sig = '</tr>';
$arr = explode($sig, $htm);
$htm = $arr[0];

// REFORMAT THE DATA INTO A TILDE-SEPARATED STRING
$new = trim(strip_tags($htm));
$new = explode(PHP_EOL, $new);
$new = implode(' ~ ', $new);

// SHOW THE WORK PRODUCT
var_dump($new);

最诚挚的问候,〜雷


0
投票

您是否尝试过将数组输出为 print_f($value) 以查看它是否具有您需要的数据?如果所有股票都有相同的模式,并且您用“~”将它们内爆,我相信数组的第一个元素将包含“NASDAQ: GOOD”,第二个“NASDAQ-100 Component”,因此通过输出数组您将获得所需的数据。

© www.soinside.com 2019 - 2024. All rights reserved.