首頁 > 後端開發 > php教程 > 利用PHP和coreseek實現精準的食譜搜尋功能

利用PHP和coreseek實現精準的食譜搜尋功能

王林
發布: 2023-08-05 13:18:02
原創
1511 人瀏覽過

利用PHP和coreseek實現精準的食譜搜尋功能

概述:
在現今的快節奏生活中,越來越多的人開始注重自己的飲食健康。找到合適的食譜成為了一種需求。本文將介紹如何利用PHP和coreseek搜尋引擎實現精準的食譜搜尋功能,幫助使用者輕鬆找出符合自己需求的食譜。

準備工作:
在開始之前,我們需要準備一些工具:

  1. PHP環境:在本地或伺服器上建立PHP環境,確保可以執行PHP腳本。
  2. MySQL資料庫:用於儲存食譜資料。
  3. Coreseek搜尋引擎:一個基於Sphinx的全文搜尋引擎。可以從其官方網站下載最新的版本。

核心想法:

  1. 準備食譜資料並將其匯入到MySQL資料庫中。
  2. 配置並啟動Coreseek搜尋引擎。
  3. 使用PHP編寫搜尋功能的程式碼,實現使用者的輸入和搜尋結果的展示。

步驟一:準備食譜資料並匯入到MySQL資料庫中

首先,我們需要建立一個資料庫用於儲存食譜資料。可以使用phpMyAdmin等工具或直接在命令列下執行對應的SQL語句進行建立。

建立資料庫和表格的SQL語句如下所示:

CREATE DATABASE IF NOT EXISTS recipe;
USE recipe;
CREATE TABLE IF NOT EXISTS recipes (

id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
title VARCHAR(255) NOT NULL,
ingredients TEXT NOT NULL,
directions TEXT NOT NULL
登入後複製

);

接下來,我們可以透過編寫PHP腳本來讀取本地的食譜數據,並將其導入到資料庫中。假設我們的食譜資料保存在一個名為「recipes.txt」的文字檔案中,其格式如下所示:

標題1
食材1,食材2,食材3
步驟1 ,步驟2,步驟3

標題2
食材4,食材5,食材6
步驟4,步驟5,步驟6

PHP腳本程式碼如下圖:

// 開啟檔案
$handle = fopen('recipes.txt', 'r');
if ($handle) {

$title = '';
$ingredients = '';
$directions = '';

while (($line = fgets($handle)) !== false) {
    $line = trim($line);

    if ($line != '') {
        if ($title == '') {
            $title = $line;
        } elseif ($ingredients == '') {
            $ingredients = $line;
        } elseif ($directions == '') {
            $directions = $line;
        }

        if ($title != '' && $ingredients != '' && $directions != '') {
            // 将食谱数据插入数据库
            $sql = "INSERT INTO recipes (title, ingredients, directions) VALUES ('" . $title . "', '" . $ingredients . "', '" . $directions . "')";
            // 执行SQL语句
            // ...

            // 重置数据
            $title = '';
            $ingredients = '';
            $directions = '';
        }
    }
}

fclose($handle);
登入後複製

}
?>

在上述程式碼中,我們開啟了名為「recipes.txt」的檔案並逐行讀取其中的內容。透過使用空白行來區分不同食譜的標題、食材和步驟。在每次讀取完一個完整的食譜後,我們將其插入資料庫中。

步驟二:設定並啟動Coreseek搜尋引擎

首先,將下載的coreseek壓縮包解壓縮到指定的目錄下。進入Coreseek目錄,編輯設定檔“sphinx.conf”,配置以下內容:

source recipe
{

type = mysql
sql_host = localhost
sql_user = root
sql_pass = your_password
sql_db = recipe
sql_port = 3306
sql_query = SELECT id, title, ingredients, directions FROM recipes
登入後複製

}

index recipe
{

source = recipe
path = /path/to/index/recipe
docinfo = extern
min_word_len = 1
charset_type = utf-8
登入後複製

}

searchd
{

listen = 9312
log = /path/to/searchd.log
query_log = /path/to/query.log
max_matches = 1000
登入後複製

}

在上述設定中,我們定義了一個名為「recipe」的資料來源,使用了MySQL資料庫來取得食譜資料。然後,建立了一個名為「recipe」的索引,並設定了相關的路徑和配置。

儲存並退出設定檔之後,使用下列指令來啟動Coreseek搜尋引擎:

/path/to/coreseek/bin/searchd --config /path/to/coreseek/etc/ sphinx.conf

步驟三:使用PHP寫搜尋功能的程式碼

現在,我們可以使用PHP來寫搜尋功能的程式碼。假設我們的網頁上有一個搜尋表單,使用者可以在其中輸入關鍵字進行搜尋。

HTML程式碼如下圖所示:

<input type="text" name="keyword" placeholder="请输入关键词">
<input type="submit" value="搜索">
登入後複製

PHP腳本程式碼如下所示(search.php):

// 取得使用者輸入的關鍵字
$keyword = $_GET['keyword'];

// 查詢資料庫
$sql = "SELECT * FROM recipes WHERE MATCH('".$keyword."')";
// 執行SQL語句
// .. .

// 解析查詢結果
// ...

// 展示搜尋結果
// ...

?>

在上述程式碼中,我們首先取得使用者輸入的關鍵字,並將其儲存到變數$keyword。然後,我們使用MATCH關鍵字來查詢資料庫,以取得與關鍵字相符的食譜資料。這裡省略了具體的資料庫查詢和結果解析程式碼,你可以根據自己的需求來實現。

最後,在搜尋結果頁面中,我們可以根據具體的需求展示搜尋結果,例如使用循環語句來遍歷查詢到的數據,並將其以列表或卡片的形式展示給使用者。

總結:
本文介紹如何利用PHP和coreseek搜尋引擎實現精確的食譜搜尋功能。透過準備食譜資料、配置並啟動Coreseek搜尋引擎以及編寫相關的PHP程式碼,我們可以輕鬆地實現一個功能強大的食譜搜尋功能,幫助用戶快速查找到符合自己需求的食譜。同時,你也可以根據自己的需求對程式碼進行擴展和優化,以達到更好的使用者體驗。

以上是利用PHP和coreseek實現精準的食譜搜尋功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板