Simple PHP BBCode Parser

テキスト処理文字列

概要

 閲覧数:1615  投稿日:2016-02-18  更新日:2016-02-18  

Simple PHP BBCode Parser


コード

<?php
function bbcodeParser($bbcode){
/*
*
*	bbCode Parser
*
*	Syntax: bbcodeParser(bbcode)
*/

/*
Commands include
* bold
* italics
* underline
* typewriter text
* strikethough
* images
* urls
* quotations
* code (pre)
* colour
* size
*/

/* Matching codes */
$urlmatch = "([a-zA-Z]+[:\/\/]+[A-Za-z0-9\-_]+\\.+[A-Za-z0-9\.\/%&=\?\-_]+)";

/* Basically remove HTML tag's functionality */
$bbcode = htmlspecialchars($bbcode);

/* Replace "special character" with it's unicode equivilant */
$match["special"] = "/\�/s";
$replace["special"] = '&#65533;';

/* Bold text */
$match["b"] = "/\[b\](.*?)\[\/b\]/is";
$replace["b"] = "<b>$1</b>";

/* Italics */
$match["i"] = "/\[i\](.*?)\[\/i\]/is";
$replace["i"] = "<i>$1</i>";

/* Underline */
$match["u"] = "/\[u\](.*?)\[\/u\]/is";
$replace["u"] = "<span style=\"text-decoration: underline\">$1</span>";

/* Typewriter text */
$match["tt"] = "/\[tt\](.*?)\[\/tt\]/is";
$replace["tt"] = "<span style=\"font-family:monospace;\">$1</span>";

$match["ttext"] = "/\[ttext\](.*?)\[\/ttext\]/is";
$replace["ttext"] = "<span style=\"font-family:monospace;\">$1</span>";

/* Strikethrough text */
$match["s"] = "/\[s\](.*?)\[\/s\]/is";
$replace["s"] = "<span style=\"text-decoration: line-through;\">$1</span>";

/* Color (or Colour) */
$match["color"] = "/\[color=([a-zA-Z]+|#[a-fA-F0-9]{3}[a-fA-F0-9]{0,3})\](.*?)\[\/color\]/is";
$replace["color"] = "<span style=\"color: $1\">$2</span>";

$match["colour"] = "/\[colour=([a-zA-Z]+|#[a-fA-F0-9]{3}[a-fA-F0-9]{0,3})\](.*?)\[\/colour\]/is";
$replace["colour"] = $replace["color"];

/* Size */
$match["size"] = "/\[size=([0-9]+(%|px|em)?)\](.*?)\[\/size\]/is";
$replace["size"] = "<span style=\"font-size: $1;\">$3</span>";

/* Images */
$match["img"] = "/\[img\]".$urlmatch."\[\/img\]/is";
$replace["img"] = "<img src=\"$1\" />";

/* Links */
$match["url"] = "/\[url=".$urlmatch."\](.*?)\[\/url\]/is";
$replace["url"] = "<a href=\"$1\">$2</a>";

$match["surl"] = "/\[url\]".$urlmatch."\[\/url\]/is";
$replace["surl"] = "<a href=\"$1\">$1</a>";

/* Quotes */
$match["quote"] = "/\[quote\](.*?)\[\/quote\]/ism";
$replace["quote"] = "<div class=\"bbcode-quote\">�$1�</div>";

$match["quote"] = "/\[quote=(.*?)\](.*?)\[\/quote\]/ism";
$replace["quote"] = "<div class=\"bbcode-quote\"><span class=\"bbcode-quote-user\" style=\"font-weight:bold;\">$1 said:</span><br />�$2�</div>";

/* Parse */
$bbcode = preg_replace($match, $replace, $bbcode);

/* New line to <br> tag */
$bbcode=nl2br($bbcode);

/* Code blocks - Need to specially remove breaks */
function pre_special($matches)
{
	$prep = preg_replace("/\<br \/\>/","",$matches[1]);
	return "�<pre>$prep</pre>�";
}
$bbcode = preg_replace_callback("/\[code\](.*?)\[\/code\]/ism","pre_special",$bbcode);


/* Remove <br> tags before quotes and code blocks */
$bbcode=str_replace("�<br />","",$bbcode);
$bbcode=str_replace("�","",$bbcode); //Clean up any special characters that got misplaced...

/* Return parsed contents */
return $bbcode;
}
?>



タグ


preg_replace 





「1文字目」から「最初の指定文字」前までの文字列を取得

「半角スペースもしくは全角スペースで区切られた文字列」先頭に指定文字列を付与



週間人気ページランキング / 6-1 → 6-7
順位 ページタイトル抜粋 アクセス数
1 PHPコード 25
2 PHPで最後の「指定区切り文字」より後ろを取得 | 配列(型) 11
3 ログイン 4
3 foreachの中でswitch文 | 配列(型) 4
4 文字列の先頭に0があった場合に、取り除く | 文字列(テキスト処理) 3
5 条件分岐 カテゴリー 2
5 指定文字列より前を取得 | 文字列(テキスト処理) 2
6 Smarty(テンプレートエンジン) カテゴリー 1
6 if | タグ毎エントリー一覧 1
6 平均値、分散、標準偏差を求める | 統計 1
6 本日が「複数設定した指定日」の当日に該当するか、を判定 | 日付および時刻関連 1
6 m | タグ毎エントリー一覧 1
6 文字列(テキスト処理) カテゴリー 1
6 array_slice | タグ毎エントリー一覧 1
6 PHPでExcelの統計関数を実装 | 統計 1
6 配列要素を、文字列連結して表示(元配列に変化なし) … foreach文+implode | 配列(型) 1
6 「range(int または numeric string または string)で生成した複数配列」をマージした結果の型を確認 | 配列(型) 1
6 「数字」「アルファベット小文字」「アルファベット大文字」の順番で表示 | 文字列(テキスト処理) 1
6 stdClassで構成された連想配列を生成 | ビルトインクラス(クラス) 1
6 8桁の生年月日数字から、年齢を計算 | 日付および時刻関連 1
2026/6/8 5:05 更新