2014-10-17 110 views
0

我想那些2的preg_replace合并成一个单一one.For例如更换每data-thumb-bg="style="background-image: url('后,如果有.jpg.jpg);更换。组合两个的preg_replace成一个

$input = preg_replace('#data-thumb-bg="#s', 'style="background-image: url(', $input); 
$input = preg_replace('#.jpg#s', '.jpg);', $input); //this must be executed only if a match has been found for above 

我该怎么做?

编辑

我想我已经错了我的意思

.jpg应更换只有data-thumb-bg=一直replaced.Like首先你更换data-thumb-bg那么你替换遵循的.jpgdata-thumb-bg

亲切的问候

回答

5

我假设你的最终目标是到元素的属性data-thumb-bg="photo.jpg"改为style="background-image: url(photo.jpg);"。这可以使用capture groupbackreference(注意:s modifier是不必要的,因为我们不使用.)来完成:如果您希望只允许.jpg extensions

$input = preg_replace('/data-thumb-bg="([^"]+)"/', 'style="background-image: url(\1);"', $input); 

RegEx Demo


,你可以使用以下表达式:

data-thumb-bg="([^"]+?\.jpg)" 

或者如果您只想允许a handful of image extensions,你可以使用这样的表达式:

data-thumb-bg="([^"]+?\.(?:jpe?g|png|gif))" 
+1

你明白了......完美.Thx很多 – user2650277 2014-10-17 17:35:08

2

您可以将数组传递给preg_replace中的模式和替换参数。

$pattern = array('#data-thumb-bg="#s', '#.jpg#s'); 
$replace = array('style="background-image: url(', '.jpg);'); 
$content = preg_replace($pattern, $replace, $input); 
+1

事实上它也能工作,但请记住,当你使用的模式阵列,目标字符串被解析模式一次(如'str_replace') – 2014-10-17 17:46:50