python 操作es 定义函数,先读后写

 

from elasticsearch import Elasticsearch
from elasticsearch import helpers
import datetime
from ES import setting
import time

#定义es链接
def conn_to_es():
    client = Elasticsearch(hosts=["http://{0}:{1}".format(setting.ES_HOST, setting.ES_PORT)],
                           http_auth=(setting.ES_USER, setting.ES_PASSWORD))
    return client

es = conn_to_es()


#定义读取es函数
def read_es(index,query=""):
    if es.ping():
        print("Successfully connect!")
    else:
        print("Failed.....")
        exit()
    if query == "":  # query为es的搜索条件
        query = {
            "query": {
                "match_all": {}
            },
            # "size":1000
        }
    res = helpers.scan(es, index=index, scroll="20m", query=query)
    return res

# 连接到集群,提供节点,不一定要全部节点
# es = Elasticsearch(["172.16.208.149:9200"])

# 打开文件准备读取数据
file_name = 'test.txt'
wbfile = open(file_name, 'r', encoding='utf-8', errors='ignore')
actions = []

# 循环每一行,写入数据
for line in wbfile:
    fields = line.split('#')
    # print(fields)
    # print(fields[2])
    action = {
        "_index": "estest_2019_04_19",
        "_type": "_doc",
        "_id": int(fields[0]),
        "_source": {"sid": int(fields[0]),
                    "c@receive_time": datetime.datetime.strptime("2020-04-19 16:30:16", "%Y-%m-%d %H:%M:%S"),
                    "sname": fields[1],
                    "sage": int(fields[2]),
                    "score": int(fields[3])
                    }
                    }

    actions.append(action)
    # 每1完条批量导入一次
    if len(actions)==1000:
        # helper批量导入
        helpers.bulk(es, actions)
        actions = []
        print("insert 10000")
if len(actions) > 0:
    # 导入最后剩余的数据
    helpers.bulk(es, actions)
print("finish")

time.sleep(10)

#定义读es

data=read_es("estest_2019_04_19",query="")
for i in data:
	print(i) #i是一个字典类型









 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值