preg_replace按顺序替换相同的内容怎么实现?

WBOY
リリース: 2016-06-06 20:15:06
オリジナル
1474 人が閲覧しました

$row['goods_desc']里的内容包含很多个alt=""
我需要把第一个alt=""替换成"替换后的内容11111"
第二个alt=""替换成"替换后的内容22222"
第三个alt=""替换成"替换后的内容33333"
以此类推,直到把内容里的所有alt="" 替换完。
请问如果编写这个需求的代码?原代码如下:原代码实现的结果是把所有的alt="" 都替换成了$row['goods_name']
这个不是我想要的结果。
$row['goods_desc'] = preg_replace('/alt=([\'|\"]){2}/','alt="'.$row['goods_name'].'"',$row['goods_desc']);

回复内容:

$row['goods_desc']里的内容包含很多个alt=""
我需要把第一个alt=""替换成"替换后的内容11111"
第二个alt=""替换成"替换后的内容22222"
第三个alt=""替换成"替换后的内容33333"
以此类推,直到把内容里的所有alt="" 替换完。
请问如果编写这个需求的代码?原代码如下:原代码实现的结果是把所有的alt="" 都替换成了$row['goods_name']
这个不是我想要的结果。
$row['goods_desc'] = preg_replace('/alt=([\'|\"]){2}/','alt="'.$row['goods_name'].'"',$row['goods_desc']);

preg_replace的第一个参数和第二个参数用数组对应起来。

<code><?php $string = 'The quick brown fox jumped over the lazy dog.';
$patterns = array();
$patterns[0] = '/quick/';
$patterns[1] = '/brown/';
$patterns[2] = '/fox/';
$replacements = array();
$replacements[2] = 'slow';
$replacements[1] = 'black';
$replacements[0] = 'bear';
echo preg_replace($patterns, $replacements, $string);
?>
</code>
ログイン後にコピー

以上例程会输出:

<code>The slow black bear jumped over the lazy dog.</code>
ログイン後にコピー

preg_replace_callback

使用preg_replace_callback

如果按你的需求的话,那么就应该使用这个方法。

<code>$string = "your text";
$array = $your_row;
$count = 1;
function your_call_back($matches){
    global $count;
    $count = intval($count++);
    // 此处$count的值是你调用次数的值,如果需要考虑是否会数组越界的话,可以
    // isset$array[$count] 获取数组是否越界
    return "替换后的内容".$array[$count]."_".$count;
}
echo preg_replace_callback('/alt=""/',"your_call_back",$string);
</code>
ログイン後にコピー

<code><?php $i = 0;
function cb($m) {
    $replace_arr = ['111', '222', '333'];
    global $i;
    $replace_str = $replace_arr[$i++] ? : $replace_arr[$i=0];
    return '替换后的内容'.$replace_str;
}
echo preg_replace_callback('/alt=""/', 'cb', $str);
</code></code>
ログイン後にコピー
関連ラベル:
php
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート