此示例代码的目标是弄清楚如何创建由多个过滤器和查询组成的查询。
以下示例未按预期工作。
- 我希望能够仅对包含某个“密钥”的文档执行搜索。这就是我试图通过 ExistsFilter 达到的目标,但是启用时我没有得到任何结果。
有什么指示可以解决这个问题吗?
#!/usr/bin/python
import pyes
conn = pyes.ES('sandbox:9200')
conn.index('{"test":{"field1":"value1","field2":"value2"}}','2012.9.23','test')
filter = pyes.filters.BoolFilter()
filter.add_must(pyes.filters.LimitFilter(1))
filter.add_must(pyes.filters.ExistsFilter('test')) #uncommenting this line returns the documents
query = pyes.query.BoolQuery()
query.add_must(pyes.query.TextQuery('test.field1','value1'))
query.add_must(pyes.query.TextQuery('test.field2','value2'))
search = pyes.query.FilteredQuery(query, filter)
for reference in conn.search(query=search,indices=['2012.9.23']):
print reference