win10通过impyla连接Hive

由于win系统上无法正常使用PyHive访问Hive,所以改用impyla访问。
参考:走马兰台

环境:

python 3.7.3,Win10

安装依赖:

six-1.13.0
bit-array-0.1.0
pure-sasl 0.6.2
thrift-sasl-0.2.1
thrift 0.9.3
thriftpy-0.3.9
impyla-0.16.2

修改部分源码:

报错:TypeError: can't concat str to bytes 需要在文件 ".\Python37\lib\site-packages\thrift_sasl\__init__.py"第94行代码

def _send_message(self, status, body):

    header = struct.pack(">BI", status, len(body))

    self._trans.write(header + body)

    self._trans.flush()

改为

def _send_message(self, status, body):

    header = struct.pack(">BI", status, len(body))

    if(type(body) is str):

        body = body.encode()

    self._trans.write(header + body)

    self._trans.flush()

测试:

from impala.dbapi import connect
conn = connect(host='test.com', port=10000, auth_mechanism='PLAIN', user='admin', password='pwd', database='db_test')
cur=conn.cursor()
cur.execute('SHOW TABLES')
cur.fetchall()

保存,用jupyter写代码的记得要restart kernel。

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TracelessLe

❀点个赞加个关注再走吧❀

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值