php - 如何通过html内容获取href和文本内容
问题描述
我想获取包含所有其他 td 数据的内容和 url。
我的代码:
$context = stream_context_create(
array(
"http" => array(
"header" => "User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.102 Safari/537.36"
)
)
);
$htmlContent = file_get_contents("https://www.iana.org/domains/root/db", false, $context);
$DOM = new DOMDocument();
$DOM->loadHTML($htmlContent);
$FirstdTable = $DOM->getElementsByTagName('table')->item(0);
$Header = $FirstdTable->getElementsByTagName('th');
$Detail = $FirstdTable->getElementsByTagName('td');
//#Get header name of the table
foreach($Header as $NodeHeader)
{
$aDataTableHeaderHTML[] = trim($NodeHeader->textContent);
}
//#Get row data/detail table without header name as key
$i = 0;
$j = 0;
foreach($Detail as $sNodeDetail)
{
$aDataTableDetailHTML[$j][] = trim($sNodeDetail->textContent);
$i = $i + 1;
$j = $i % count($aDataTableHeaderHTML) == 0 ? $j + 1 : $j;
}
电流输出:
Array
(
[0] => Array
(
[0] => .aaa
[1] => generic
[2] => American Automobile Association, Inc.
)
[1] => Array
(
[0] => .aarp
[1] => generic
[2] => AARP
)
[2] => Array
(
[0] => .abarth
[1] => generic
[2] => Fiat Chrysler Automobiles N.V.
)
}
我想在这里:
Array
(
[0] => Array
(
[0] => .aaa
[1] => generic
[2] => American Automobile Association, Inc.
[3] => https://www.iana.org/domains/root/db/aaa.html
)
[1] => Array
(
[0] => .aarp
[1] => generic
[2] => AARP
[3] => https://www.iana.org/domains/root/db/aarp.html
)
[2] => Array
(
[0] => .abarth
[1] => generic
[2] => Fiat Chrysler Automobiles N.V.
[3] => https://www.iana.org/domains/root/db/abarth.html
)
}
解决方案
目前,您只是在 all <td>
's 中获取所有文本内容。它不会在锚标签内包含链接。为此,您需要深入挖掘<td>
.
这是一种使用方法xpath
:
$xpath = new DOMXpath($DOM);
$base = 'https://www.iana.org/';
foreach($Detail as $sNodeDetail)
{
$aDataTableDetailHTML[$j][] = trim($sNodeDetail->textContent);
if ($link = $xpath->evaluate("string(./span[contains(@class, 'domain')]/a/@href)", $sNodeDetail)) {
$aDataTableDetailHTML[$j][] = "{$base}{$link}";
}
$i = $i + 1;
$j = $i % count($aDataTableHeaderHTML) == 0 ? $j + 1 : $j;
}
基本上,如果迭代中href
的当前具有并获取值,则查询只是提取值。<td>
<span class="domain tld"><a href="xxxx">xxx</a></span>
href
另一种方法是迭代 each<tr>
而不是 each <td>
:
$aDataTableDetailHTML = [];
$DOM = new DOMDocument();
$DOM->loadHTML($htmlContent);
$xpath = new DOMXpath($DOM);
$base = 'https://www.iana.org/';
foreach($xpath->query('//table[@id="tld-table"]/tbody/tr') as $row) {
$domain = trim($xpath->evaluate("string(./td[1])", $row));
$type = $xpath->evaluate("string(./td[2])", $row);
$tld_manager = $xpath->evaluate("string(./td[3])", $row);
$url = $xpath->evaluate("string(./td[1]/span/a/@href)", $row);
$aDataTableDetailHTML[] = [$domain, $type, $tld_manager, "{$base}{$url}"];
}
推荐阅读
- javascript - 在反应中更新单个字段不起作用
- java - Getting No such File or Directory Exception on Ubuntu when trying compile a java project from java.lang.Process
- c++ - GCC 对编译时字符串文字的支持
- zsh - zmv - 如果有多个连续的大写字母,则不改变大小写
- python - OOP Pygame 平台游戏:控制和移动屏幕上的方块
- jsonschema - 我们如何在ajv中使用''$data''和''required''?
- youtube-api - 如何从频道获取当前活跃的直播流?
- python - Timing the shortcircuit in Python gives unexpected results
- java - 以编程方式更改 SIM 国家/地区?
- python - 如何将变量从类传递到另一个类?