項目結構:
開始搜尋: 這裡搜尋索引鍵("大""這")
開始搜尋: 這裡搜尋索引鍵("大""這")
搜尋結果: 高亮顯示
項目所需資料庫結構:
資料庫連接檔案
| 代碼如下 |
複製代碼 |
<?php $conn = @ mysql_connect("localhost", "root", "") or die("資料庫連結錯誤"); mysql_select_db("form", $conn); mysql_query("set names 'gbk'"); ?> |
給加色的searchAndDisplayWithColor.php檔案
| 代碼如下 |
複製代碼 |
<?php include 'conn.php'; ?> <table width=500 align="center"> <form action="" method="get"> <tr> <td>關鍵字:<input type="text" name="keyWord" /> <input type="submit" value="搜尋" /></td> </tr> </form> </table> <table width=500 border="0" align="center" cellpadding="5" cellspacing="1" bgcolor="#add3ef"> <?php //關鍵字不為空白的時候才執行相關搜尋 if($_GET['keyWord']){ //用空格符把關鍵字分割開 $key=explode(' ', $_GET[keyWord]); $sql="select * from message where title like '$key[0]' or title like '$key[1]' or content like '$key[0]' or content like '%$key[1]%'"; $query=mysql_query($sql); while ($row=mysql_fetch_array($query)){ //替換關鍵字,並且把關鍵字高亮顯示 $row[title]=preg_replace("/$key[0]/i", "<font color=red><b>$key[0]</b></font>", $row[title]); $row[title]=preg_replace("/$key[0]/i", "<font color=red><b>$key[1]</b></font>", $row[title]); $row[content]=preg_replace("/$key[0]/i", "<font color=red><b>$key[0]</b></font>", $row[content]); $row[content]=preg_replace("/$key[1]/i", "<font color=red><b>$key[1]</b></font>", $row[content]); ?> <tr bgcolor="#eff3ff"> <td>標題:<font color="black"><?=$row[title]?></font> 使用者:<font color="black"><?=$row[user] ?></font> <div align="right"><a href="preEdit.php?id=<?=$row[id]?>">編輯</a> | <a href="delete.php?id=<?=$row[id]?>">刪除</a></div> </td> </tr> <tr bgColor="#ffffff"> <td>內容:<?=$row[content]?></td> </tr> <tr bgColor="#ffffff"> <td> <div align="right">發表日期:<?=$row[lastdate]?></div> </td> </tr> <?php } } ?> </table> |
說明:在這個小程式中,有一點不足之處在於,只能同時搜尋兩個關鍵字,並且中間用空格" "隔開,如果只是搜尋一個關鍵字,如:"大"
顯示的時候會出現亂碼 ……^|_|^,這是由於下面代碼的結果:
用空格符把關鍵字分割開
| 代碼如下 |
複製代碼 |
$key=explode(' ', $_GET[keyWord]);
|
如果要改進的話,在這裡的後面就要做一下判斷了。
總結,
上面的關鍵詞高亮只是一個非常簡單的使用者提交過來什麼我們就對這個關鍵詞進行了str_replace進行高亮顯示了,如果要做得更好可利用dedecms分詞系統進行分詞再操作會好很多哦。
關於dedecms分詞程式實現方法可參考
一個用PHP寫的中文分詞函數
http://www.111cn.net/phper/24/c8b9ff7300e56c042014a655b0bd6e34.htm
中文分詞的php代碼
http://www.111cn.net/phper/php-gj/39302.htm
php做的簡單中文分詞代碼
http://www.111cn.net/phper/php-gj/38506.htm