侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

python elasticsearch从创建索引到写入数据的全过程

Python  /  管理员 发布于 3年前   154

python elasticsearch从创建索引到写入数据

创建索引

from elasticsearch import Elasticsearches = 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 Elasticsearches = 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 Elasticsearchfrom elasticsearch.helpers import bulkes = 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 Elasticsearches = 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 Elasticsearches = 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 Elasticsearches = 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 Elasticsearches = 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从创建索引到写入数据的全过程,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!


  • 上一条:
    Python 操作 ElasticSearch的完整代码
    下一条:
    解决spring mvc 返回json数据到ajax报错parseerror问题
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • python爬虫BeautifulSoup快速抓取网站图片(0个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • VSCode Python开发环境配置的详细步骤(0个评论)
    • 使用 Visual Studio Code(VSCode)搭建简单的Python+Django开发环境的方法步骤(0个评论)
    • 解决vscode python print 输出窗口中文乱码的问题(0个评论)
    • 近期文章
    • 如何优雅处理async await错误推荐:await-to-js库(0个评论)
    • lodash工具库(0个评论)
    • 在Laravel项目中使用中间件方式统计用户在线时长功能代码示例(0个评论)
    • 在Laravel中构建业务流程模型(0个评论)
    • windows系统中安装FFMpeg及在phpstudy环境php7.3 + php-ffmpeg扩展的使用流程步骤(0个评论)
    • 在go语言中对浮点的数组、切片(slice)进行正向排序和反向排序(0个评论)
    • 在go语言中对整数数组、切片(slice)进行排序和反向排序(0个评论)
    • 在go语言中对字符串数组、切片(slice)进行排序和反向排序(0个评论)
    • 最新国内免注册ChatGPT体验站_ChatGPT镜像站访问链接地址2023/3/28持续更新(0个评论)
    • 在Laravel项目中的实现无密码认证之:发送邮箱链接授权(0个评论)
    • 近期评论
    • 博主 在

      2023年国务院办公厅春节放假通知:1月21日起休7天中评论 @ xiaoB 你只管努力,剩下的叫给天意;天若有情天亦老,..
    • xiaoB 在

      2023年国务院办公厅春节放假通知:1月21日起休7天中评论 会不会春节放假后又阳一次?..
    • BUG4 在

      你翻墙过吗?国内使用vpn翻墙可能会被网警抓,你需了解的事中评论 不是吧?..
    • 博主 在

      go语言+beego框架中获取get,post请求的所有参数中评论 @ t1  直接在router.go文件中配就ok..
    • Jade 在

      如何在MySQL查询中获得当月记录中评论 Dear zongscan.com team, We can skyroc..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客