Програматичне використання API пошуку


30

Проблема: Потрібно запустити власні пошукові програми програмно за допомогою API пошуку. Кожен результат, який я знаходжу в Google, орієнтований на те, щоб навчити непрограмістів використовувати модуль з представленнями, без результатів робити це так, як я хочу.

Інформація:

  • Використання локальної служби баз даних замість Solr або будь-якої іншої.
  • Нехай дані не зберігаються в базі даних, які з'являться поряд з іншими результатами.
  • Вміст буде згруповано у вкладках "тип".
  • Не використовуйте Views з різних причин.
  • Увімкнено API Facets, але немає поняття, як ним також користуватися.

Чому: Тому що я хочу, щоб сторінка пошуку знаходилась за адресою / пошук на сайті та без / вузла / ключового слова після аргументу сторінки. Також буде запропоновано налаштувати це за межі інших модулів, які можуть забезпечувати однаковий тип функціональності. І я хочу навчитися це робити, але не знайшов ніяких навчальних посібників чи іншого розуміння того, як це зробити.

Решта: я створив свою пошукову сторінку і на ній я виконую пошук за допомогою:

$term = $_SESSION['my-search']['term'];
$server = search_api_server_load('database');
$index = search_api_index_load('default_node_index');
$query = new SearchApiQuery($index);
$query->keys($term); 
$query->fields(array('title','body:value')); 
$srv= new SearchApiDbService($server);
$result = $srv->search($query);

Змінна сеансу встановлюється під час подання пошукової форми, а потім перенаправляє користувача на сайт / пошук, щоб здійснити пошук та показати результати.

Якщо я вивожу $ result, я бачу, що це масив з різною інформацією, включаючи набір результатів, який є масивом ідентифікаторів вузлів та їхніх балів.

Я міг би пройти через них, схопивши вузол і сам відобразивши результати, але, думаю, має бути якийсь інший метод для відображення результатів пошуку. Я цього не знайшов, і в цьому проблема.

Я переглядав різні класи в API пошуку API і Facet API і не можу знайти в них нічого, що, здавалося б, створило б результат.

Будь-яка допомога з цим буде вдячна.

Приклад результатів:

Array
(
[result count] => 11
[results] => Array
    (
        [37] => Array
            (
                [id] => 37
                [score] => 15.7503318786621
            )

        [39] => Array
            (
                [id] => 39
                [score] => 7
            )

        [40] => Array
            (
                [id] => 40
                [score] => 5
            )

        [31] => Array
            (
                [id] => 31
                [score] => 4
            )

        [33] => Array
            (
                [id] => 33
                [score] => 1
            )

        [36] => Array
            (
                [id] => 36
                [score] => 1
            )

        [1] => Array
            (
                [id] => 1
                [score] => 1
            )

        [15] => Array
            (
                [id] => 15
                [score] => 1
            )

        [16] => Array
            (
                [id] => 16
                [score] => 1
            )

        [27] => Array
            (
                [id] => 27
                [score] => 1
            )

        [35] => Array
            (
                [id] => 35
                [score] => 0.980873763561249
            )

    )

[warnings] => Array
    (
    )

[ignored] => Array
    (
    )

[performance] => Array
    (
        [complete] => 0.0033111572265625
        [preprocessing] => 0.00053095817565918
        [execution] => 0.0027379989624023
        [postprocessing] => 4.2200088500977E-5
    )

)

Чи можете ви надати дамп масиву результатів для контексту? Ви можете передати це прямо на topic_search_resulta
Clive

1
"Я міг би пройти через них, захопивши вузол і відобразивши результати, але я думаю, що має бути якийсь інший метод надання результатів пошуку. Я не знайшов цього, і в цьому проблема". - node_view_multiple () ?
Гаррет Олбрайт

Клайв: Я оновив своє запитання щодо результатів пошуку. Гаррет: Дякую, що вказав на цю функцію, не знав, що вона існує. Це буде корисно для деяких інших проектів, але не має відношення до того, що я хочу тут робити. :) Передбачається виділення ключових слів і відображення відповідного тексту пошуку в класах API API пошуку, але я не зміг зрозуміти, як отримати результати для відображення за допомогою цих методів. Дякуємо за допомогу поки що! :)
Джейсон Грей

Ви спробували переглянути функції пошуку в API Drupal? api.drupal.org/api/drupal/modules!search!search.module/7
Agi Hammerthief

Ви використовували їх у ситуації, яку я описав у своєму запитанні?
Джейсон Грей

Відповіді:


4

Ви подивилися модуль сторінок API пошуку . Він використовує модуль API API пошуку та створює користувацьку сторінку пошуку. Ви, напевно, могли б подивитися на цей модуль підказки щодо того, як реалізувати те, що ви намагаєтеся зробити. Сам модуль може навіть забезпечити багато функціональних можливостей, які ви шукаєте.


1
Попросили рішення, яке явно не використовувало сторінки чи перегляди
Daniel Waters

Ні, він сказав: "Не використовуючи Views з різних причин". Модуль API пошуку не працює. Вибачте, якщо моя пропозиція не допомогла
n30r3b3l

2
Я б погодився з тим, що модуль сторінок API пошуку - це гарне початкове місце! Раніше я впроваджував користувальницький пошук і використовував код у якості вихідної точки, що можна зробити без використання сторінок!
paaat

1

Ось моє рішення приблизно в 100 рядках - трохи простіше, ніж сторінки ...

define('SEARCH_QUERY_TERM', 'query');
define('SEARCH_PAGE_TERM', 'page');
define('SEARCH_LIMIT_TERM', 'limit');
define('SEARCH_DEFAULT_LIMIT', 10);

/**
 * Implements hook_menu().
 */
function my_module_menu() {
    $items['search'] = array(
        'title' => 'Search',
        'page callback' => 'my_module_page',
        'access callback' => TRUE,
        'type' => MENU_CALLBACK,
    );

    return $items;
}

/**
 * My Module Search Functions
 */

function my_module_page() {
    $build = array(
        'form' => drupal_get_form('my_module_form'),
        'results' => array('#theme_wrappers' => array('container')),
    );

    foreach (my_module_result() as $eid => $entity) {
        $build['results'][$eid] = entity_view('node', array($entity), 'teaser');
    }

    return $build;
}

function my_module_form($form, &$form_state) {
    list($query, $page, $limit) = my_module_params();

    $form['query'] = array(
        '#type' => 'textfield',
        '#title' => t('Search'),
        '#default_value' => $query,
    );
    $form['actions'] = array('#type' => 'actions');
    $form['actions']['submit'] = array(
        '#type' => 'submit',
        '#value' => t('Search'),
    );

    return $form;
}

function my_module_form_submit($form, &$form_state) {
    $values = $form_state['values'];
    $query = isset($values['query']) ? $values['query'] : '';
    $form_state['redirect'] = array('search', array('query' => array('query' => $query)));
}

function my_module_params() {
    $query = '';
    $page_number = 0;
    $limit = SEARCH_DEFAULT_LIMIT;
    $params = drupal_get_query_parameters();

    if (isset($params[SEARCH_QUERY_TERM])) {
        $query = $params[SEARCH_QUERY_TERM];
    }
    if (isset($params[SEARCH_PAGE_TERM]) && is_numeric($params[SEARCH_PAGE_TERM])) {
        $page_number = $params[SEARCH_PAGE_TERM];
    }
    if (isset($params[SEARCH_LIMIT_TERM]) && is_numeric($params[SEARCH_LIMIT_TERM])) {
        $limit = $params[SEARCH_LIMIT_TERM];
    }

    return array($query, $page_number, $limit);
}

function my_module_result() {
    $index_id = 'default_node_index';

    list($keys, $page_number, $limit) = my_module_params();
    $offset = $limit * $page_number;

    $options = array(
        'search id' => 'node:default',
    );

    $query = search_api_query($index_id, $options)->keys($keys);

    if ($limit > 0) {
        $query->range($offset, $limit);
    }

    $results = $query->execute();
    $results = isset($results['results']) ? $results['results'] : array();

    return entity_load('node', array_keys($results));
}

1
Використовуйте переспрямування стану, а не drupal_goto.
Кевін
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.