2014-10-16 77 views
-1

在下面的例子中,我的数组返回空。我需要将(完整!)图像链接放入我的数组中。Array returns empty

这是我的代码:

<?php 
    header('Content-Type: text/html; charset=utf-8'); 
    $url = "http://www.asaphshop.nl/epages/asaphnl.sf/nl_NL/?ObjectPath=/Shops/asaphnl/Products/80203122"; 
    $htmlcode = file_get_contents($url); 
    $pattern = "/class=\"noscript\"\>(.*?)\<\/div\>/imU"; 
    preg_match_all($pattern, $htmlcode, $matches); 
    //print_r ($matches); 
    $image = ($matches[0]); 
    print_r ($image); 
?> 

这是我使用的尝试,并取得(完成!)图片链接到我的数组文件的一部分:

<div id="ProductImages" class="noscript"> 
    <ul> 
     <li> 
     <a href="/WebRoot/products/8020/80203122/bilder/80203122.jpg"> 
      <img 
      itemprop="image" 
      alt="Jesus Remember Me - Taize Songs (2CD)" 
      src="/WebRoot/AsaphNL/Shops/asaphnl/5422/8F43/62EE/D698/EF8E/4DEB/AED5/3B0E/80203122_xs.jpg" 
      data-src-xs="/WebRoot/AsaphNL/Shops/asaphnl/5422/8F43/62EE/D698/EF8E/4DEB/AED5/3B0E/80203122_xs.jpg" 
      data-src-s="/WebRoot/products/8020/80203122/bilder/80203122_s.jpg" 
      data-src-m="/WebRoot/products/8020/80203122/bilder/80203122_m.jpg" 
      data-src-l="/WebRoot/products/8020/80203122/bilder/80203122.jpg" 
     /> 
     </a> 
     </li> 
    </ul> 
    </div> 
+2

你应该** ** NEVER解析HTML用正则表达式。 – zessx 2014-10-16 10:02:02

+0

为什么不呢?我不明白。 – bananaman 2014-10-16 10:04:15

回答

0

第一:你不应该用正则表达式解析HTML,因为HTML太复杂,不能像那样解析。看看this post

对于你的问题,你的问题是你使用多行修饰符而不是单行修饰符。改变你的正则表达式为这一个:

/class=\"noscript\"\>(.*?)\<\/div\>/isU 

如果你想要一个干净的结果,用这个(与回顾后/超前):

/(?<=class=\"noscript\"\>)(.*?)(?=\<\/div\>)/isU 
+0

谢谢,但现在我的数组仍然不好,这是现在的链接:http://localhost/WebRoot/products/8020/80203122/bilder/80203122.jpg 但它需要退出本地主机,如下所示: http://www.asaphshop.nl/WebRoot/products/8020/80203122/bilder/80203122.jpg我该怎么做? – bananaman 2014-10-16 10:17:49

+0

这是另一个问题。你应该用'src =“http:// www.asaphshop.nl /'来替换每一个'src =”/'。相同的,'data-src-xs =“/','href =”/'... – zessx 2014-10-16 10:31:13