有很多库可以做这件事,比如pyes和pyelasticsearch。pyes搜索website看起来不错,pyelasticsearch采取了另一种方法,但也没问题。
另一方面,这段代码可以工作,而且非常简单。
import urllib2 as urllib
import json
import pprint
query = {
"from":0,
"size":10,
"query":{
"field" : {
"name" : "david"
}
},
"sort":[
{"name":"asc"},
{"lastName":"asc"}
]
}
query = json.dumps(query)
response = urllib.urlopen(
'http://localhost:9200/users/users/_search',
query
)
result = json.loads( response.read() )
pprint.pprint(result)因此,我正在考虑使用简单的代码,而不是学习库的技巧。
发布于 2012-09-27 19:23:44
您使用REST API与ElasticSearch进行交互的方法没有任何问题。
Pyes和其他库为REST API提供了一个包装器,这样您就可以编写Python代码,而不必自己构建JSON查询。
发布于 2019-10-02 20:30:04
请注意,问题中所示的代码片段在Python3中不起作用。用户必须对查询字符串进行编码,并向请求中添加内容标头。因此,在Python 3中执行以下操作:
from urllib.request import urlopen, Request
import json
import pprint
query = {
"from":0,
"size":10,
"query":{
"field" : {
"name" : "david"
}
},
"sort":[
{"name":"asc"},
{"lastName":"asc"}
]
}
# encode your json string
query = json.dumps(query).encode("utf-8")
# add a content-type header
request = Request('http://localhost:9200/users/users/_search', data=query, headers={'Content-Type': 'application/json'})
response = urlopen(request)
result = json.loads( response.read() )
pprint.pprint(result)https://stackoverflow.com/questions/12605982
复制相似问题