我正在尝试使用自定义查询DSL来使用pyes库获取结果。我有查询DSL,当我使用命令行时可以工作
curl -XGET localhost:9200/test_index/_search -d '{
"query": {
"function_score": {
"query": {
"match_all": {}
},
"field_value_factor": {
"field": "starred",
"modifier": "none",
"factor": 2
}
}
},
"aggs" : {
"types" : {
"filters" : {
"filters" : {
"category1" : { "type" : { "value" : "category1"}},
"category2" : { "type" : { "value" : "category2"}},
"category3" : { "type" : { "value" : "category3"}},
"category4": { "type" : { "value" : "category4"}},
"category5" : { "type" : { "value" : "category5"}}
}
},
"aggs": {
"topFoundHits": {
"top_hits": {
"size": 5
}
}
}
}
}
}'
这里的想法是在许多分类文档中搜索与特定字符串查询匹配的所有文档。然后使用聚合,我想按类别查找结果文档的前五名。星号项目会被提升,以便它们显示在其他搜索结果之上。
当我直接在终端中输入上面列出的命令时,这非常有效,但当我试图将其放入pyes时,它就不起作用了。我不确定最好的方法是什么。pyes库的文档真的让我很困惑,无法将其完全转换为pyes对象。
我正在尝试以下操作:
query_dsl = self.get_text_index_query_dsl()
resulting_docs = conn.search(query=query_dsl)
(其中self.get_test_index_query_dsl
返回上面的查询dsl dict)
按原样搜索给了我一个:ElasticSearchException: QueryParsingException[[test_index] No query registered for [query]]; }]
如果我删除父"查询"映射并尝试:
query_dsl = {
"function_score": {
"query": {
"match_all": {}
},
"field_value_factor": {
"field": "starred",
"modifier": "none",
"factor": 2
}
},
"aggs" : {
"types" : {
"filters" : {
"filters" : {
"category1" : { "type" : { "value" : "category1"}},
"category2" : { "type" : { "value" : "category2"}},
"category3" : { "type" : { "value" : "category3"}},
"category4": { "type" : { "value" : "category4"}},
"category5" : { "type" : { "value" : "category5"}}
}
},
"aggs": {
"topFoundHits": {
"top_hits": {
"size": 5
}
}
}
}
}
}
这也会出错:ElasticSearchException: ElasticsearchParseException[Expected field name but got START_OBJECT "aggs"]; }]
这些错误,再加上pyes似乎还没有"topFoundHits"功能(我认为),让我很头疼。
你知道为什么会发生这种情况以及如何解决吗?非常感谢!
我使用这个库完成了这项工作,您可以在这里使用常规查询dsl JSON语法:http://elasticsearch-dsl.readthedocs.org/en/latest/.