亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

python elasticsearch從創(chuàng)建索引到寫入數據的全過程

系統(tǒng) 1596 0

python elasticsearch從創(chuàng)建索引到寫入數據

創(chuàng)建索引

            
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)
          

通過以上代碼即可創(chuàng)建es索引

寫入一條數據

寫入數據需要根據 創(chuàng)建的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)
          

即可寫入一條數據

錯誤的寫入

python elasticsearch從創(chuàng)建索引到寫入數據的全過程_第1張圖片

正確的寫入

python elasticsearch從創(chuàng)建索引到寫入數據的全過程_第2張圖片

寫入多條數據

            
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從創(chuàng)建索引到寫入數據的全過程,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 天天干天天碰 | 国产亚洲男人的天堂在线观看 | 老司机亚洲精品影院在线 | 欧美日韩91 | 99久久精品国产免费 | 精品国产第一国产综合精品 | 国产福利免费在线观看 | 免费观看午夜在线欧差毛片 | 日韩欧美综合视频 | 99精品在免费线视频 | 天天操天天搞 | 日韩美女中文字幕 | 日韩在线一区二区三区视频 | 手机看片久久高清国产日韩 | 日韩在线视频网站 | 色视频网站在线观看 | 国内精品视频免费观看 | 停停色 | 国产伦码精品一区二区三区 | 午夜视频久久久久一区 | 婷婷综合 | 久操精品视频 | 97国内免费久久久久久久久久 | 国产一区二区影院 | 欧美综合图区 | 99久久精品国产片 | 日本高清不卡免费 | 亚洲综合视频在线 | 日韩免费一级毛片 | 成人一级片在线观看 | 国产精品亚洲一区二区麻豆 | 淫视频在线观看 | 成人精品一区二区三区校园激情 | 毛片一级在线观看 | www国产精品com| 久久久久亚洲精品影视 | 最新国产精品久久精品 | 婷婷精品 | 国产探花一区 | 亚洲一区二区在线免费观看 | 久久久国产一区二区三区 |