我想在WordPress搜索结果中添加/注入/附加额外的结果。
目前,WordPress只允许您“调整”在其自己的数据库上执行的查询,但不允许您修改(或在WordPress中使用,过滤)结果数组。
I.e:如果在WordPress中我搜索“马铃薯”一词,所有与此术语相关的帖子都会回来。我想将通过不同服务获得的结果包含在WordPress结果集中。
为了澄清,我从第三方API调用中获得了结果。不是来自WordPress数据库。
有没有人知道如何做到这一点?
编辑:最好这需要在我的WordPress插件中进行,而无需更改搜索模板。
答案 0 :(得分:6)
您可以使用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');
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');
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' );
答案 1 :(得分:2)
这个问题可能已经过时了,但我遇到了类似的问题,未来的某些人也可能会这样,所以我会发布我的(更好的)解决方案。
如上所述,将api查询结果保存在wp_posts-table中可能是最干净的解决方案(可能是自定义帖子类型)并对它们执行普通的WP-Search。
但在我的情况下,我不得不处理另一个缓存一些外部数据的表并将其链接到现有帖子的ID,我无法改变这种结构。
因此,Abhineet Verma的解决方案(search_filter + pre_get_posts)起初似乎很有用,但最终它不适合我。我能够在查询结果中添加其他帖子,但它们不适合结果的正常分页。例如,如果要在每页显示10个结果并使用上面的解决方案并从api获得20个结果,则每页将有30个结果:十个正常结果,属于页面加上每页上的二十个结果。它还打破了一些分页插件。
所以我终于解决了以下问题。我使用过滤器posts_search来扩展sql-query:
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;
});
看起来有点奇怪,但效果很好。也许有时会对某人有所帮助!