Python插入Elasticsearch操作方法解析
这篇文章主要介绍了Python插入Elasticsearch操作方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
在用scrapy做爬虫的时候,需要将数据存入的es中。网上找了两种方法,照葫芦画瓢也能出来,暂记下来:
首先安装了es,版本是5.6.1的较早版本
用pip安装与es版本相对的es相关包
pipinstallelasticsearch-dsl==5.1.0
方法一:
以下是pipelines.py模块的完整代码
#-*-coding:utf-8-*- #Defineyouritempipelineshere # #Don'tforgettoaddyourpipelinetotheITEM_PIPELINESsetting #See:https://docs.scrapy.org/en/latest/topics/item-pipeline.html importchardet classSinafinancespiderPipeline(object): defprocess_item(self,item,spider): returnitem #写入到es中,需要在settings中启用这个类ExchangeratespiderESPipeline #需要安装pipinstallelasticsearch-dsl==5.1.0注意与es版本需要对应 fromelasticsearch_dslimportDate,Nested,Boolean,analyzer,Completion,Keyword,Text,Integer,DocType fromelasticsearch_dsl.connectionsimportconnections connections.create_connection(hosts=['192.168.52.138']) fromelasticsearchimportElasticsearch es=Elasticsearch() classAticleType(DocType): page_from=Keyword() #domain报错 domain=Keyword() cra_url=Keyword() spider=Keyword() cra_time=Keyword() page_release_time=Keyword() page_title=Text(analyzer="ik_max_word") page_content=Text(analyzer="ik_max_word") classMeta: index="scrapy" doc_type="sinafinance" #以下settings和mappings都没起作用,暂且记下 settings={ "number_of_shards":3, } mappings={ '_id':{'path':'cra_url'} } classExchangeratespiderESPipeline(DocType): fromelasticsearch5importElasticsearch ES=['192.168.52.138:9200'] es=Elasticsearch(ES,sniff_on_start=True) defprocess_item(self,item,spider): spider.logger.info("-----enterintoinsertES") article=AticleType() article.page_from=item['page_from'] article.domain=item['domain'] article.cra_url=item['cra_url'] article.spider=item['spider'] article.cra_time=item['cra_time'] article.page_release_time=item['page_release_time'] article.page_title=item['page_title'] article.page_content=item['page_content'] article.save() returnitem
以上方法能将数据写入es,但是如果重复爬取的话,会重复插入数据,因为主键”_id”是ES自己产生的,找不到自定义_id的入口。于是放弃。
方法二:实现自定义主键写入,覆盖插入
#-*-coding:utf-8-*- #Defineyouritempipelineshere # #Don'tforgettoaddyourpipelinetotheITEM_PIPELINESsetting #See:https://docs.scrapy.org/en/latest/topics/item-pipeline.html fromelasticsearch5importElasticsearch classSinafinancespiderPipeline(object): defprocess_item(self,item,spider): returnitem #写入到es中,需要在settings中启用这个类ExchangeratespiderESPipeline #需要安装pipinstallelasticsearch-dsl==5.1.0注意与es版本需要对应 classSinafinancespiderESPipeline(): def__init__(self): self.ES=['192.168.52.138:9200'] #创建es客户端 self.es=Elasticsearch( self.ES, #启动前嗅探es集群服务器 sniff_on_start=True, #es集群服务器结点连接异常时是否刷新es结点信息 sniff_on_connection_fail=True, #每60秒刷新节点信息 sniffer_timeout=60 ) defprocess_item(self,item,spider): spider.logger.info("-----enterintoinsertES") doc={ 'page_from':item['page_from'], 'domain':item['domain'], 'spider':item['spider'], 'page_release_time':item['page_release_time'], 'page_title':item['page_title'], 'page_content':item['page_content'], 'cra_url':item['cra_url'], 'cra_time':item['cra_time'] } self.es.index(index='scrapy',doc_type='sinafinance',body=doc,id=item['cra_url']) returnitem
搜索数据的方法:
#字典形式设置body query={ 'query':{ 'bool':{ 'must':[ {'match':{'_all':'pythonweb'}} ], 'filter':[ {'term':{'status':2}} ] } } } ret=es.search(index='articles',doc_type='article',body=query) #查询数据 data=es.search(index='articles',doc_type='article',body=body) print(data) #增加 es.index(...) #修改 es.update(...) #删除 es.delete()
完成后
在settings.py模块中注册自定义的类
ITEM_PIPELINES={ #'sinafinancespider.pipelines.SinafinancespiderPipeline':300, 'sinafinancespider.pipelines.SinafinancespiderESPipeline':300, }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。