duanjia2415 2017-12-11 10:40
浏览 71
已采纳

PHP删除元素前后的文本

I have some database rows with a lot of text but I only want to select a specific text.

Example:

<strong>Lorem</strong>
<ul>
    <li>Lorem</li>
    <li>Ipsum</li>
</ul>

<strong>Ipsum</strong>
<ul>
    <li>Ipsum</li>
    <li>Lorem</li>
</ul>

<strong>Third</strong>
<ul>
    <li>Some words</li>
    <li>More words</li>
</ul>

I only want to select the Ipsum part with the ul element and ignore the rest. I was trying to work with DOMXPath->evaluate('//text()[contains()]') but this only shows the Ipsum text and not the elements.

EDIT: The exact output I want is:

<strong>Ipsum</strong>
<ul>
    <li>Ipsum</li>
    <li>Lorem</li>
</ul>

The code I tried (I have tried more but this is the last result):

$d = new DOMDocument;
$d->loadHTML($text);

$x = new DOMXPath($d);
$result = $x->evaluate("//text()[contains(., 'Ipsum')]");

$result->item(0)->nodeValue;

This shows only the Ipsum text and not the list elements.

  • 写回答

2条回答 默认 最新

  • doubao12345 2017-12-11 11:54
    关注

    As your trying to get 2 nodes, the way I've done it is to use 2 XPath expressions...

    $d = new DOMDocument;
    $d->loadHTML($text);
    
    $x = new DOMXPath($d);
    $result = $x->evaluate("//strong[contains(., 'Ipsum')]");
    $result1 = $x->evaluate("//strong[contains(., 'Ipsum')]/following-sibling::ul");
    
    echo $d->saveHTML($result->item(0)).PHP_EOL;
    echo $d->saveHTML($result1->item(0)).PHP_EOL;
    

    Which outputs.

    <strong>Ipsum</strong>
    <ul>
    <li>Ipsum</li>
        <li>Lorem</li>
    </ul>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 R语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里