如何解决Python elasticsearch-dsl 动态构建匹配查询
使用 ElasticSearch 6.x
和 elasticsearch-dsl python 包
我正在尝试使用 match
表单和 options
元素生成 query
查询。
我有一个字段列表 fields = ['field_1','field_2']
,我正在尝试使用以下方法构建叶 match
查询
from elasticsearch_dsl.query import MultiMatch,Match,Constantscore
def _get_match(tokens,fields,boost):
for index in range(len(fields)):
field = fields[index]
print(Match(field={"query": tokens[index],"boost": boost}))
tokens = ['token_1','token_2']
fields = ['field_1','field_2']
boost = 3
_get_match(tokens,boost)
Match(field={'query': 'token_1','boost': 3})
Match(field={'query': 'token_2','boost': 3})
预期输出:
Match(field_1={'query': 'token_1','boost': 3})
Match(field_2={'query': 'token_2','boost': 3})
注意,字段值而不是数组中传递的字段值,生成的查询直接使用变量名。如何动态生成匹配查询?
如果我使用 SO Post 中提到的 **
,它确实会创建一个动态查询,但它采用简化格式。
解决方法
您已经提到了用于打开字典的 **
。工作正常,我只更改了一行:
print(Match(** {field: {"query": tokens[index],"boost": boost}}))
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。