ElasticSearch / Python 动态过滤器数量

Der*_*pos 4 python elasticsearch elasticsearch-plugin

我对编程很陌生,所以我的问题可能很愚蠢/容易做,但是:我需要根据用户输入在elasticsearch中创建多个过滤器

我的查询正文:

body = {
        "query": {
            "filtered": {
                "filter": {
                    "bool": {
                        "must": [
                            {"term": {name1: value1}},
                            {"term": {name2: value2}},
                            {"term": {name3: value3}},
                        ]
                    }
                }
            }
        },
}
Run Code Online (Sandbox Code Playgroud)

它工作正常,但我需要有这些过滤器的动态数量

我尝试将查询构建到字符串中,然后在其中添加过滤器,但 es 不允许这样做,例如:

l = []
for i_type, name in convert.items():
    string = '{"term": {"' + i_type + '":"' + name + '"}},'
    l.append(string)
i_query = ''.join(l)
Run Code Online (Sandbox Code Playgroud)

当我在查询结构中使用列表/字符串时,我从服务器收到 404 错误

是否可以添加动态数量的过滤器?

小智 5

有可能的。正文只是一个 Python字典。因此,您可以动态添加字段/术语/新过滤器等。

    body = {
    "query": {
        "filtered": {
            "filter": {
                "bool": {
                    "must": []
                    }
                }
            }
        }
   }

d = {"name_1": value_1, "name_2": value_2}
Run Code Online (Sandbox Code Playgroud)

Python 2.x

for key, value in d.iteritems():
    body1["query"]["filtered"]["filter"]["bool"]["must"].append({"term": {key: value}})
Run Code Online (Sandbox Code Playgroud)

或者更短(Python 2.x):

body1["query"]["filtered"]["filter"]["bool"]["must"].extend([{"term": {key: value}} for key,value in d.iteritems()])
Run Code Online (Sandbox Code Playgroud)

Python 3.x

for key, value in d.items():
    body1["query"]["filtered"]["filter"]["bool"]["must"].append({"term": {key: value}})  
Run Code Online (Sandbox Code Playgroud)

Python 3.x 的较短版本:

body1["query"]["filtered"]["filter"]["bool"]["must"].extend([{"term": {key: value}} for key,value in d.items()])
Run Code Online (Sandbox Code Playgroud)

基本上,您可以创建任何您想要的查询。例如,您可以轻松添加should子句:

body["query"]["filtered"]["filter"]["bool"]["should"]=[{"term": {"name_42": value_42}}]
Run Code Online (Sandbox Code Playgroud)