PHP正则提取或替换img标记属性实现文章预览

时间:2024-09-06 09:33:26

今天在想如何实现文章预览时,如果文章里面包含照片,那么就选取第一张照片作为预览图,如果没有照片,则截取文章的头150个字作为预览文字,但是因为保存在数据库的文章都是以富文本的形式,没办法直接提取,在网上找了一下,发现这段代码可以实现:

<?php
/*PHP正则提取图片img标记中的任意属性*/
$str='<center><img src="/uploads/images/20100516000.jpg" height="120" width="120"><br />PHP正则提取或更改图片img标记中的任意属性</center>'; //1、取整个图片代码
preg_match('/<\s*img\s+[^>]*?src\s*=\s*(\'|\")(.*?)\\1[^>]*?\/?\s*>/i',$str,$match);
echo$match[0]; //2、取width
preg_match('/<img.+(width=\"?\d*\"?).+>/i',$str,$match);
echo$match[1]; //3、取height
preg_match('/<img.+(height=\"?\d*\"?).+>/i',$str,$match);
echo$match[1]; //4、取src
preg_match('/<img.+src=\"?(.+\.(jpg|gif|bmp|bnp|png))\"?.+>/i',$str,$match);
echo$match[1]; /*PHP正则替换图片img标记中的任意属性*/
//1、将src="/uploads/images/20100516000.jpg"替换为src="/uploads/uc/images/20100516000.jpg")
printpreg_replace('/(<img.+src=\"?.+)(images\/)(.+\.(jpg|gif|bmp|bnp|png)\"?.+>)/i',"\${1}uc/images/\${3}",$str);
echo"<hr/>"; //2、将src="/uploads/images/20100516000.jpg"替换为src="/uploads/uc/images/20100516000.jpg",并省去宽和高
printpreg_replace('/(<img).+(src=\"?.+)images\/(.+\.(jpg|gif|bmp|bnp|png)\"?).+>/i',"\${1} \${2}uc/images/\${3}>",$str); ?>

这是我后台写的具体实现文章预览的代码:

<?php
while($row = mysql_fetch_array($result))
{
//这里我用的是第一种方法,直接提取整个img标签
$pattern="/<\s*img\s+[^>]*?src\s*=\s*(\'|\")(.*?)\\1[^>]*?\/?\s*>/i";
preg_match($pattern,$row['content'],$match); if(!empty($match))
{
$content = $match[0];
}
else
{
$content=mb_substr($row['content'],0,150,'UTF-8')."......";
}
echo $content;
}
?>

实现效果

PHP正则提取或替换img标记属性实现文章预览

正则提取代码出处:http://www.oschina.net/code/snippet_118180_4299