十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章将为大家详细讲解有关python中elasticsearch如何创建索引并写入数据,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
成都创新互联专注于尼金平企业网站建设,成都响应式网站建设公司,电子商务商城网站建设。尼金平网站建设公司,为尼金平等地区提供建站服务。全流程按需搭建网站,专业设计,全程项目跟踪,成都创新互联专业和态度为您提供的服务python elasticsearch从创建索引到写入数据
创建索引
from elasticsearch import Elasticsearch es = Elasticsearch('192.168.1.1:9200') mappings = { "mappings": { "type_doc_test": { #type_doc_test为doc_type "properties": { "id": { "type": "long", "index": "false" }, "serial": { "type": "keyword", # keyword不会进行分词,text会分词 "index": "false" # 不建索引 }, #tags可以存json格式,访问tags.content "tags": { "type": "object", "properties": { "content": {"type": "keyword", "index": True}, "dominant_color_name": {"type": "keyword", "index": True}, "skill": {"type": "keyword", "index": True}, } }, "hasTag": { "type": "long", "index": True }, "status": { "type": "long", "index": True }, "createTime": { "type": "date", "format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis" }, "updateTime": { "type": "date", "format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis" } } } } } res = es.indices.create(index = 'index_test',body =mappings)
通过以上代码即可创建es索引
写入一条数据
写入数据需要根据 创建的es索引类型对应的数据结构写入:
from elasticsearch import Elasticsearch es = Elasticsearch('192.168.1.1:9200') action ={ "id": "1111122222", "serial":"版本", #以下tags.content是错误的写法 #"tags.content" :"标签2", #"tags.dominant_color_name": "域名的颜色黄色", #正确的写法如下: "tags":{"content":"标签3","dominant_color_name": "域名的颜色黄色"}, #按照字典的格式写入,如果用上面的那种写法,会直接写成一个tags.content字段。 #而不是在tags中content添加数据,这点需要注意 "tags.skill":"分类信息", "hasTag":"123", "status":"11", "createTime" :"2018-2-2", "updateTime":"2018-2-3", } es.index(index="index_test",doc_type="doc_type_test",body = action)
即可写入一条数据
错误的写入
正确的写入
写入多条数据
from elasticsearch import Elasticsearch from elasticsearch.helpers import bulk es = Elasticsearch('192.168.1.1:9200') ACTIONS = [] action1 ={ "_index": "indes_test", "_type": "doc_type_test", "_id":"bSlegGUBmJ2C8ZCSC1R1", "_source":{ "id": "1111122222", "serial":"版本", "tags.content" :"标签2", "tags.dominant_color_name": "域名的颜色黄色", "tags.skill":"分类信息", "hasTag":"123", "status":"11", "createTime" :"2018-2-2", "updateTime":"2018-2-3", } } action2 ={ "_index": "indes_test", "_type": "doc_type_test", "_id":"bSlegGUBmJ2C8ZCSC1R2", "_source":{ "id": "1111122222", "serial":"版本", "tags.content" :"标签2", "tags.dominant_color_name": "域名的颜色黄色", "tags.skill":"分类信息", "hasTag":"123", "status":"11", "createTime" :"2018-2-2", "updateTime":"2018-2-3", } } ACTIONS.append(action1) ACTIONS.append(action2) res,_ =bulk(es, ACTIONS, index="indes_test", raise_on_error=True) print(res)
这个方式是手动指定了id,如果把”_id”这个参数去掉即可自动生成id数据.
如下:
action2 ={ "_index": "indes_test", "_type": "doc_type_test", "_source":{ "id": "1111122222", "serial":"版本", "tags.content" :"标签2", "tags.dominant_color_name": "域名的颜色黄色", "tags.skill":"分类信息", "hasTag":"123", "status":"11", "createTime" :"2018-2-2", "updateTime":"2018-2-3", } }
删除一条数据
from elasticsearch import Elasticsearch es = Elasticsearch('192.168.1.1:9200') res = es.delete(index="index_test",doc_type="doc_type_test", id ="bSlegGUBmJ2C8ZCSC1R1") print(res)
直接替换id的即可删除所需的id
查询一条数据
from elasticsearch import Elasticsearch es = Elasticsearch('192.168.1.1:9200') res = es.get(index="index_test",doc_type="doc_type_test", id ="bSlegGUBmJ2C8ZCSC1R2") print(res)
直接替换id的即可查询所需的id
查询所有数据
from elasticsearch import Elasticsearch es = Elasticsearch('192.168.1.1:9200') res = es.search(index="index_test",doc_type="doc_type_test") print(res) print(res['hits']['hits'])
通过['hits']参数,可以解析出查询数据的详细内容
根据关键词查找
from elasticsearch import Elasticsearch es = Elasticsearch('192.168.1.1:9200') doc = { "query": { "match": { "_id": "aSlZgGUBmJ2C8ZCSPVRO" } } } res = es.search(index="index_test",doc_type="doc_type_test",body=doc) print(res)
关于“python中elasticsearch如何创建索引并写入数据”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。