在discuz中,回帖表(forum_post)中的message欄位中的內容是以如下形式儲存的:
$message = "[i=s] \u672c\u5e16\u6700\u540e\u7531 areyouok \u4e8e 2016-3-5 15:12 \u7f16\u8f91 [\/i]\n\n[attach]41[\/attach][attach]10[\/attach]\u592a\u9633\u5149\uff0c\u91d1\u4eae\u4eae\uff0c\u96c4\u9e21\u9ad8\u9ad8\u5531\r\n";
其中[attach]與[\/attach]中間的部分是附件Id,我需要擷取出來然後找到具體附件的內容。
這裡就需要使用phpRegex來擷取開始字串與結束字串之間的內容,放到一個數組中
一些是測試通過的代碼:
//擷取開始字串後的一段字元
$subject = '"./uploads/meinian/96140234039638604.html"\n"./uploads/meinian/json_30_60393801_20140924.txt"';
$pattern = '#"\./uploads/meinian/(.*?)"#i';
$items = preg_match_all($pattern, $subject, $matches);
var_dump($matches);
echo '
';
//擷取開始字串和結尾字串之間的部分
$subject = "[i=s] \u672c\u5e16\u6700\u540e\u7531 areyouok \u4e8e 2016-3-5 15:12 \u7f16\u8f91 [\/i]\n\n[attach]41[\/attach][attach]10[\/attach]\u592a\u9633\u5149\uff0c\u91d1\u4eae\u4eae\uff0c\u96c4\u9e21\u9ad8\u9ad8\u5531\r\n";
$pattern = '#\[attach](.*?)\[\\\/attach]#i';
$items = preg_match_all($pattern, $subject, $matches);
$target = preg_replace($pattern,'',$subject);
echo 'target='.$target.'';
var_dump($matches);
echo '';
?>
以上就介紹了phpRegex 擷取開始字串和結束字串中的部分內容,包括了方面的內容,希望對PHP教程有興趣的朋友有所協助。