Maison  >  Questions et réponses  >  le corps du texte

Utilisez preg_match_all pour analyser des balises bbcode supplémentaires

J'ai deux types de bbcode : [附件]1234[/附件] [attach=full]1234[/attach]

$message = 'this is message with attach [attach=full]1234[/attach]

Je souhaite supprimer tout ce qui se trouve dans la chaîne et utiliser :

(preg_match_all('/\[ATTACH((.*?)\](.+?)\[\/ATTACH\]/i', $message, $out, PREG_SET_ORDER))
if (preg_match_all('/\[ATTACH((.*?)\](.+?)\[\/ATTACH\]/i', $message, $out, PREG_SET_ORDER))
{   
    for ($i=0;$i<count($out);$i++)
    {
        $replace_src[] = $out[$i][0];
        $replace_str[] = $out[$i][1];
        $newMessage = str_ireplace($replace_src, $replace_str, $message);
    }
}

Ce code supprime [attach][/attach], mais pas [attach=full][/attach] =full Soyez dans le message.

P粉086993788P粉086993788223 Il y a quelques jours438

répondre à tous(1)je répondrai

  • P粉138711794

    P粉1387117942024-04-03 16:14:32

    Utilisez preg_replace(),而不是preg_match_all().

    Utilisez des groupes facultatifs pour faire correspondre attach 后的可选 =xxx.

    $newMessage = preg_replace('/\[ATTACH(?:=.*?)?\](.+?)\[\/ATTACH\]/i', '', $message);

    répondre
    0
  • Annulerrépondre