dtlab08822 2017-11-01 05:47
浏览 1288
已采纳

使用xpath从background-image样式属性中提取值

Ii have the follow structure:

<div class="xGh" style="background-image: url('name_file.jpg');"></div>

I need that output:

name_file.jpg

I try use that answer, but dont work fo me :

$img = $xpath->query(substring-before(substring-after(//div[@class='xGh']/@style, "background-image: url('"), "')"));    

echo $img->item($i)->nodeValue."<br/>";

Look the error:

Test Ideone with error

I have some error in that sintaxe i cant see how is correct...

sry my english

  • 写回答

1条回答 默认 最新

  • dongxun1142 2017-11-01 13:40
    关注

    1) You lost quotes wrapping xpath - it's string.

    2) with dom xpath, query returns set of nodes while to receive string result it's better to use evaluate

    $img = $xpath->evaluate('substring-before(substring-after(//div[@class=\'xGh\']/@style, "background-image: url(\'"), "\')")');    
    
    echo $img; // it contains name_file.jpg
    

    demo

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?