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 gg加速器加速游戏时,提示不是x86架构
  • ¥15 python按要求编写程序
  • ¥15 Python输入字符串转化为列表排序具体见图,严格按照输入
  • ¥20 XP系统在重新启动后进不去桌面,一直黑屏。
  • ¥15 opencv图像处理,需要四个处理结果图
  • ¥15 无线移动边缘计算系统中的系统模型
  • ¥15 深度学习中的画图问题
  • ¥15 java报错:使用mybatis plus查询一个只返回一条数据的sql,却报错返回了1000多条
  • ¥15 Python报错怎么解决
  • ¥15 simulink如何调用DLL文件