程序员人生 网站导航

php 匹配字符中链接地址程序代码

栏目:php教程时间:2013-11-13 07:57:17

判断一个字符串是否含有超级链接,代码如下:

  1. $str="ssdsf<a target='_blank' href='http://www.phpfensi.com/' >sdf</a>sdfss"
  2. if(preg_match("/<a/s+href=[^>]*>|<//[^a]*a[^>]*>/i",$str)) 
  3. echo "该字符串有超链接"
  4. else 
  5. echo "该字符串没有超链接标记"
  6. ?> 

下面我们只要过滤连接部份,代码如下:

  1. <?php  
  2. echo preg_replace("/(?<=href=)([^>]*)(?=>)/i","#""<a href='www.phpfensi.com'>你好,点这里看看</a><a href='www.phpfensi.com'>你好,点这里看看</a>");  
  3. ?> 

正则:/(?<=href=)([^>]*)(?=>)/

(?<=exp) 匹配exp后面的位置 

(?=exp) 匹配exp前面的位置 

此正则匹配 在 href= 之后 “>” 之前 的 非 “>” 的所有字符

例子:<a href='www.phpfensi.com'>,找到这些字符(url)用 # 替换,就可以去掉html里的所有链接,现在分享一个提取超级连接的实例,代码如下:

  1. function match_links($document) {    
  2.     preg_match_all("'<s*as.*?hrefs*=s*(["'])?(?(1)(.*?)1|([^s>]+))[^>]*>?(.*?)</a>'isx",$document,$links);                        
  3.     while(list($key,$val) = each($links[2])) { 
  4.         if(!emptyempty($val)) 
  5.             $match['link'][] = $val
  6.     } 
  7.     while(list($key,$val) = each($links[3])) { 
  8.         if(!emptyempty($val)) 
  9.             $match['link'][] = $val
  10.     }        
  11.     while(list($key,$val) = each($links[4])) { 
  12.         if(!emptyempty($val)) 
  13.             $match['content'][] = $val
  14.     } 
  15.     while(list($key,$val) = each($links[0])) { 
  16.         if(!emptyempty($val)) 
  17.             $match['all'][] = $val
  18.     }                
  19.     return $match
  20. }
------分隔线----------------------------
------分隔线----------------------------

最新技术推荐