使用Python API有条件地更新ElasticSearch文档

时间:2016-06-27 19:29:11

标签: python elasticsearch mappings

我正在尝试更新文档(通过将元素附加到列表中),或者创建它是否不存在。例如,我希望包含id == Donald_Duck的文档添加列表suggestions的元素(如果不存在)。

name = 'Donald_Duck'
suggestions = ['Donald', 'Donald duck', 'Duck', 'Duck Avanger']
body = {
           "script" : "ctx._source.text += new_suggetions",
           "params" : { "new_suggestions" : suggestions},
            "upsert" : suggestions
        }


es.update(index=INDEX_NAME, doc_type='test', id=name, body=body)

不幸的是我收到了RequestError

RequestError: TransportError(400, 'mapper_parsing_exception', 'failed to parse')  

这就是我的映射的样子:

mappings = {
  "mappings": {
    "test": { 
      "properties": { 
        "text":    { 
                    "type": "completion", 
                    "analyzer" : "simple",
                    "search_analyzer" : "simple" 
        }, 
      }
    }
  }
}

我该如何解决这个问题? 如果我有多个文档,我可以使用bulk API使用相同的代码吗?

1 个答案:

答案 0 :(得分:2)

你体内有一些错字:

body = {
    "script": "ctx._source.text += new_suggestions",
    "params": { "new_suggestions" : suggestions},
    "upsert": {
        "text": suggestions
    }
}

另外,您确定已启用更新脚本。请阅读https://www.elastic.co/guide/en/elasticsearch/reference/current/modules-scripting.html