python hbase读取数据发送kafka的方法


Posted in Python onDecember 27, 2018

本例子实现从hbase获取数据,并发送kafka。

使用

#!/usr/bin/env python
#coding=utf-8
 
import sys
import time
import json
 
sys.path.append('/usr/local/lib/python3.5/site-packages')
from thrift import Thrift
from thrift.transport import TSocket
from thrift.transport import TTransport
from thrift.protocol import TBinaryProtocol
from hbase1 import Hbase #调用hbase thrif1
from hbase1.ttypes import *
from kafka import KafkaConsumer
from kafka import KafkaProducer
from kafka.errors import KafkaError
import unittest
 
class HbaseOpreator:
 def __init__(self,host,port,table='test'):
  self.tableName=table
  self.transport=TTransport.TBufferedTransport(TSocket.TSocket(host,port))
  self.protocol=TBinaryProtocol.TBinaryProtocol(self.transport)
  self.client=Hbase.Client(self.protocol)
  self.transport.open()
 
 def __del__(self):
  self.transport.close()
 
 
 def scanTablefilter(self,table,*args):
  d=dict() 
  L=[]
  try:
   tableName=table
   # scan = Hbase.TScan(startRow, stopRow)
   scan=TScan()
   #主键首字母123
   # filter = "PrefixFilter('123_')"
   # filter = "RowFilter(=,'regexstring:.aaa')"
   #过滤条件,当前为 statis_date 字段,值为20170223
   # fitler = "SingleColumnValueFilter(tableName,'f','statis_date','20170223')"
   # filter="SingleColumnValueFilter('f','statis_date',=,'binary:20170223') AND SingleColumnValueFilter('f','name',=,'binary:LXS')"
   filter="SingleColumnValueFilter('info','name',=,'binary:lilei') OR SingleColumnValueFilter('info','name',=,'binary:lily')"
   scan.filterString=filter
   id=self.client.scannerOpenWithScan(tableName,scan,None)
   result=self.client.scannerGet(id)
   # result=self.client.scannerGetList(id,100)
   while result:
    for r in result:
     key=r.row
     name=r.columns.get('info:name').value
     age=r.columns.get('info:age').value
     phone=r.columns.get('info:phone').value
     d['key']=key
     d['name']=name
     d['age']=age
     d['phone']=phone
     # encode_result_json=json.dumps(d).encode(encoding="utf-8")
     # print(encode_result_json)
     L.append(d)         
    result=self.client.scannerGet(id)    
   return json.dumps(L).encode(encoding="utf-8")  
  finally:
   # self.client.scannerClose(scan)
   print("scan finish")
 
def sendKfafkaProduct(data):
 # self.host_port='localhost:9092'
 producer = KafkaProducer(bootstrap_servers=['localhost:9092'])
 for d in data:
  producer.send('test', key=b'lxs', value=d)
  time.sleep(5)
  print(d)
 
 while True:
  producer.send('test', key=b'lxs', value=data)
  time.sleep(5)
  print(data)
 
if __name__== '__main__':
 # unittest.main()
 
 B=HbaseOpreator('10.27.1.138',9090)
 value=B.scanTablefilter('ns_lbi:test_hbase_student')
 print(value)
 #sendKfafkaProduct(value)

以上这篇python hbase读取数据发送kafka的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python语言技巧之三元运算符使用介绍
Mar 04 Python
Python编程中装饰器的使用示例解析
Jun 20 Python
python常见排序算法基础教程
Apr 13 Python
Python解析json之ValueError: Expecting property name enclosed in double quotes: line 1 column 2(char 1)
Jul 06 Python
python代码实现ID3决策树算法
Dec 20 Python
Python 12306抢火车票脚本
Feb 07 Python
python的staticmethod与classmethod实现实例代码
Feb 11 Python
pycharm创建scrapy项目教程及遇到的坑解析
Aug 15 Python
numpy:np.newaxis 实现将行向量转换成列向量
Nov 30 Python
python logging 日志的级别调整方式
Feb 21 Python
python 中不同包 类 方法 之间的调用详解
Mar 09 Python
Django模板标签{% for %}循环,获取制定条数据实例
May 14 Python
Python类和对象的定义与实际应用案例分析
Dec 27 #Python
在python环境下运用kafka对数据进行实时传输的方法
Dec 27 #Python
kafka-python批量发送数据的实例
Dec 27 #Python
Python闭包思想与用法浅析
Dec 27 #Python
对python操作kafka写入json数据的简单demo分享
Dec 27 #Python
python消费kafka数据批量插入到es的方法
Dec 27 #Python
Python通过paramiko远程下载Linux服务器上的文件实例
Dec 27 #Python
You might like
PHP中上传大体积文件时需要的设置
2006/10/09 PHP
多重?l件?合查?(二)
2006/10/09 PHP
PHP采用自定义函数实现遍历目录下所有文件的方法
2014/08/19 PHP
PHP解密Unicode及Escape加密字符串
2015/05/17 PHP
PHP新特性详解之命名空间、性状与生成器
2017/07/18 PHP
前台js调用后台方法示例
2013/12/02 Javascript
jQuery实现瀑布流布局
2014/12/12 Javascript
jquery实现动态操作select选中
2015/02/11 Javascript
AngularJS表单编辑提交功能实例
2015/02/13 Javascript
JQuery移动页面开发之屏幕方向改变与滚屏的实现
2015/12/03 Javascript
Jquery easyui开启行编辑模式增删改操作
2016/01/14 Javascript
JavaScript创建对象_动力节点Java学院整理
2017/06/27 Javascript
jQuery的时间datetime控件在AngularJs中的使用实例(分享)
2017/08/17 jQuery
Node.js使用Koa搭建 基础项目
2018/01/08 Javascript
JavaScript实现飞舞的泡泡效果
2020/02/07 Javascript
Vue组件模板及组件互相引用代码实例
2020/03/11 Javascript
Javascript实现秒表计时游戏
2020/05/27 Javascript
在nodejs中创建child process的方法
2021/01/26 NodeJs
[52:57]2014 DOTA2国际邀请赛中国区预选赛 LGD-CDEC VS HGT
2014/05/21 DOTA
[01:08:43]DOTA2-DPC中国联赛定级赛 Phoenix vs DLG BO3第一场 1月9日
2021/03/11 DOTA
python插入排序算法的实现代码
2013/11/21 Python
Python中的XML库4Suite Server的介绍
2015/04/14 Python
深入理解Python中range和xrange的区别
2017/11/26 Python
python2.x实现人民币转大写人民币
2018/06/20 Python
python+unittest+requests实现接口自动化的方法
2018/11/29 Python
详解django2中关于时间处理策略
2019/03/06 Python
python的列表List求均值和中位数实例
2020/03/03 Python
手把手教你将Flask应用封装成Docker服务的实现
2020/08/19 Python
python中strip(),lstrip(),rstrip()函数的使用讲解
2020/11/17 Python
Clos19英国:高档香槟、葡萄酒和烈酒在线购物平台
2020/07/10 全球购物
在校生党员自我评价
2013/09/25 职场文书
医师定期考核实施方案
2014/05/07 职场文书
共青团员自我评价范文
2014/09/14 职场文书
法院干警四风问题自我剖析材料
2014/09/29 职场文书
postgresql无序uuid性能测试及对数据库的影响
2021/06/11 PostgreSQL
微信小程序中使用vant框架的具体步骤
2022/02/18 Javascript