Python elasticsearch-dsl 动态构建匹配查询

问题描述

使用 ElasticSearch 6.xelasticsearch-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}}))

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...