将结果添加到WordPress搜索结果中

Rub*_*ben 6 php wordpress search wordpress-plugin

我想在WordPress搜索结果中添加/注入/追加额外的结果.

目前,WordPress只允许您"调整"在其自己的数据库上执行的查询,但不允许您修改(或在WordPress术语中,过滤)结果数组.

即:如果在WordPress中我搜索"马铃薯"一词,所有与此术语相关的帖子都会回来.我想将通过不同服务获得的结果包含在WordPress结果集中.

只是为了澄清,我从第三方API调用中得到了我的结果.不是来自WordPress数据库.

有没有人知道如何做到这一点?

编辑:最好这需要在我的WordPress插件中进行,而无需更改搜索模板.

Abh*_*rma 7

您可以使用pre_get_posts添加/编辑搜索结果而无需更改搜索模板.

排除页面

排除搜索结果中的网页.可以通过仅显示帖子的结果来创建限制搜索结果的操作挂钩.

以下示例演示了如何执行此操作:

function search_filter($query) {
  if ( !is_admin() && $query->is_main_query() ) {
    if ($query->is_search) {
      $query->set('post_type', 'post');
    }
  }
}

add_action('pre_get_posts','search_filter');
Run Code Online (Sandbox Code Playgroud)

在搜索结果中包含自定义帖子类型

function search_filter($query) {
  if ( !is_admin() && $query->is_main_query() ) {
    if ($query->is_search) {
      $query->set('post_type', array( 'post', 'movie' ) );
    }
  }
}

add_action('pre_get_posts','search_filter');
Run Code Online (Sandbox Code Playgroud)

包括自定义/ API结果

function search_filter() {
    if ( is_search() ) {
        // Do your API call here
        // Save retrieved data in your wordpress
        // This will also help to you avoid api call for repeated queries.
        $post_id = wp_insert_post( $post, $wp_error ); // wp_insert_post() // Programatically insert queries result into your wordpress database
        array_push( $query->api, $post_id );
    }
}
add_action('pre_get_posts','search_filter');    
function have_posts_override(){
    if ( is_search() ) {
        global $wp_query;
        $api_post = $wp_query->api;
        foreach ($api_post as $key) {
        // This will enable you to add results you received using API call
        // into default search results.
            array_push($wp_query->posts, $key); 
        }
    }
}
add_action( 'found_posts', 'have_posts_override' );
Run Code Online (Sandbox Code Playgroud)

参考:


Paf*_*low 5

这个问题可能很老了,但我也遇到了类似的问题,将来也可能有人遇到这样的问题,所以我会发布我的(更好的)解决方案。

如上所述,将 api 查询结果保存在 wp_posts-table 中(可能作为自定义帖子类型)并对它们执行正常的 WP-Search 是最干净的解决方案。

但就我而言,我必须处理另一个表,该表缓存了一些外部数据并将其链接到现有帖子的 ID,并且我无法更改此结构。

因此,Abhineet Verma 的解决方案(search_filter + pre_get_posts)一开始看起来很有用,但最终它不适合我。我能够向查询结果添加其他帖子,但它们不适合结果的正常分页。例如,如果您想每页显示 10 个结果,并使用上述解决方案并从 api 获取 20 个结果,则每页将有 30 个结果:属于该页面的 10 个正常结果加上每个页面上的全部 20 个结果。它还破坏了一些分页插件。

所以我最终解决了这个问题如下。我使用过滤器 posts_search 来扩展 sql 查询:

add_filter('posts_search', function($sql) {

    if (!$sql) {
        return $sql;
    }

    global $wpdb;
    $sqst = "select id from {$wpdb->prefix}mytable ... bla bla ->  query to my custom table, wich return a bunch of IDs";
    $sqlr = "AND (({$wpdb->prefix}posts.ID in ($sqst)) or (1 = 1 $sql))";

    return $sqlr;

});
Run Code Online (Sandbox Code Playgroud)

它看起来有点奇怪,但效果很好。也许有时会对某人有所帮助!