[英]Finding and removing html tags with PHP Simple HTML DOM Parser
這是我正在使用的代碼:
include 'simple_html_dom.php';
$html = file_get_html('index.html');
echo $html->find('tr', 15);
這將找到表的第 15 行。 我想要做的是完全刪除該行。
我已經試過了
$html->find('tr', 15)=null;
但這似乎不起作用。 我曾嘗試在SimpleHTMLDom 文檔中查找信息,但它沒有包含太多信息。
simple_html_dom 似乎不允許刪除。
試試這個:
$html = new DOMDocument();
$html->loadHTMLFile('index.html');
$element = $html->getElementsByTagName('tr')->item(15);
$element->parentNode->removeChild($element);
在這里你有一個工作示例(在 Linux 中工作,但很容易適應)。
文件dom_test.php
:
#!/usr/bin/php
<?php
$html = new DOMDocument();
$html->loadHTMLFile('index.html');
$element = $html->getElementsByTagName('tr')->item(1);
$element->parentNode->removeChild($element);
echo $html->saveHTML();
?>
其中index.html
包含:
<html>
<head></head>
<body>
<table>
<tr><td> hi </td><td>there</td></tr>
<tr>
<td> HELLO </td>
<td> there </td>
</tr>
<tr><td> hi </td><td>there</td></tr>
</table>
</body>
</html>
將這兩個文件放在同一目錄中並在控制台中執行:
php dom_test.php
輸出將不顯示“HELLO there”行。
我希望這對你有幫助。
你可以用simple_html_dom來做到這一點,只需將outertext設置為innertext的值
foreach($html->find('div') as $div) {
$div->outertext = $div->innertext;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.