python elasticsearch update,用python进行elasticsearch部分更新

本文介绍如何使用Python在Elasticsearch中正确执行部分更新操作,遇到ScriptException问题后,提供了解决方案,通过直接修改源文档字段实现'x'字段的更新并添加Python字典。
摘要由CSDN通过智能技术生成

I have a elasticsearch document in the following format. I need to partial update the "x" field and add a python dict in it.

{

"_index": "gdata34",

"_type": "gdat",

"_id": "328091-72341-118",

"_version": 1,

"_score": 1,

"_source": {

"d": {

"Thursday": {

"s": ""

},

"Email": {

"s": ""

},

"Country": {

"s": "US"

},

},

"x": {

"Geo": {

"s": "45.335428,-118.057133",

"g": [

-118.057133

,

45.335428

]

}

},

}

}

I tried the following code to update:

from elasticsearch import Elasticsearch, exceptions

import pprint

elasticsearch = Elasticsearch()

doc = elasticsearch.get(index='gdata34', doc_type='gdat', id='328091-72341-7')

elasticsearch.update(index='gdata34', doc_type='gdat', id='328091-72341-7',

body={"script":"ctx._source.x += y",

"params":{"y":"z"}

}

)

elasticsearch.indices.refresh(index='gdata34')

new_doc = elasticsearch.get(index='gdata34', doc_type='gdat', id='328091-72341-7')

I am getting this error:

elasticsearch.exceptions.RequestError: TransportError(400, u'ElasticsearchIllegalArgumentException[failed to execute script]; nested: ScriptException[dynamic scripting for [groovy] disabled]; ')

What is the right way to do partial update in elasticsearch using python?

解决方案

For future reference, the following method of partial update worked.

elasticsearch.update(index='gdata34', doc_type='gdat', id='328091-72341-7',

body={

'doc': {'x': {'y':'z'}}

}

)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值