DDR爱好者之家 Design By 杰米
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从创建索引到写入数据的全过程,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2025年10月28日
2025年10月28日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]

