python导出hive数据表的schema实例代码


Posted in Python onJanuary 22, 2018

本文研究的主要问题是python语言导出hive数据表的schema,分享了实现代码,具体如下。

为了避免运营提出无穷无尽的查询需求,我们决定将有查询价值的数据从mysql导入hive中,让他们使用HUE这个开源工具进行查询。想必他们对表结构不甚了解,还需要为之提供一个表结构说明,于是编写了一个脚本,从hive数据库中将每张表的字段即类型查询出来,代码如下:

#coding=utf-8 
import pyhs2 
from xlwt import * 
 
hiveconn = pyhs2.connect(host='10.46.77.120', 
         port=10000, 
         authMechanism='PLAIN', 
         user='hadoop', 
         database='hibiscus_data', 
         ) 
 
def create_excel(): 
  sql = 'show tables' 
  tables = [] 
  with hiveconn.cursor() as cursor: 
    cursor.execute(sql) 
    res = cursor.fetch() 
    for table in res: 
      tables.append(table[0]) 
   
  tableinfo = [] 
  for table in tables: 
    tableinfo.append(get_column_info(table)) 
 
  create_excel_ex(tableinfo) 
 
def create_excel_ex(tableinfo): 
  w = Workbook() 
  sheet = w.add_sheet(u'表结构') 
  row = 0 
  for info in tableinfo: 
    row = write_tale_info(info,sheet,row) 
  w.save('hive_schema.xls') 
 
def write_tale_info(tableinfo,sheet,row): 
  print row 
  sheet.write_merge(row,row,0,2,tableinfo['table']) 
   
  row += 1 
  sheet.write(row,0,u'名称') 
  sheet.write(row,1,u'类型') 
  sheet.write(row,2,u'解释') 
  row += 1 
 
  fields = tableinfo['fields'] 
  for field in fields: 
    sheet.write(row,0,field['name']) 
    sheet.write(row,1,field['type']) 
    row += 1 
 
  return row + 1  
   
   
def get_column_info(table): 
  sql = 'desc {table}'.format(table=table) 
  info = {'table':table,'fields':[]} 
  with hiveconn.cursor() as cursor: 
    cursor.execute(sql) 
    res = cursor.fetch() 
    for item in res: 
      if item[0] == '': 
        break 
      info['fields'].append({'name':item[0],'type':item[1]}) 
 
  return info 
 
if __name__ == '__main__': 
  create_excel()

其实,我们的hive数据库将所有的元数据存储在了mysql当中,分析这些元数据也可以获得表结构信息。

总结

以上就是本文关于python导出hive数据表的schema实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

Python 相关文章推荐
python继承和抽象类的实现方法
Jan 14 Python
Python文档生成工具pydoc使用介绍
Jun 02 Python
python中__call__内置函数用法实例
Jun 04 Python
Python如何import文件夹下的文件(实现方法)
Jan 24 Python
python多线程socket编程之多客户端接入
Sep 12 Python
python的格式化输出(format,%)实例详解
Jun 01 Python
关于PyTorch源码解读之torchvision.models
Aug 17 Python
django-crontab 定时执行任务方法的实现
Sep 06 Python
pycharm 更改创建文件默认路径的操作
Feb 15 Python
Python实现删除某列中含有空值的行的示例代码
Jul 20 Python
解决Python3.8运行tornado项目报NotImplementedError错误
Sep 02 Python
教你用python实现12306余票查询
Jun 30 Python
Python的SimpleHTTPServer模块用处及使用方法简介
Jan 22 #Python
一道python走迷宫算法题
Jan 22 #Python
浅谈使用Python内置函数getattr实现分发模式
Jan 22 #Python
python正则表达式及使用正则表达式的例子
Jan 22 #Python
Python深度优先算法生成迷宫
Jan 22 #Python
Python使用Tkinter实现机器人走迷宫
Jan 22 #Python
Python实现简单文本字符串处理的方法
Jan 22 #Python
You might like
星际争霸兵种名称对照表
2020/03/04 星际争霸
php 操作数组(合并,拆分,追加,查找,删除等)
2012/07/20 PHP
javascript 一些用法小结
2009/09/11 Javascript
dtree 网页树状菜单及传递对象集合到js内,动态生成节点
2012/04/14 Javascript
Jquery多选下拉列表插件jquery multiselect功能介绍及使用
2013/05/24 Javascript
window.navigate 与 window.location.href 的使用区别介绍
2013/09/21 Javascript
Js实现双击鼠标自动滚动屏幕的示例代码
2013/12/14 Javascript
JavaScript获取table中某一列的值的方法
2014/05/06 Javascript
原生JavaScript生成GUID的实现示例
2014/09/05 Javascript
js点击button按钮跳转到另一个新页面
2014/10/10 Javascript
jQuery实现表格颜色交替显示的方法
2015/03/09 Javascript
jQuery实现购物车数字加减效果
2015/03/14 Javascript
Bootstrap开发实战之第一次接触Bootstrap
2016/06/02 Javascript
js制作支付倒计时页面
2016/10/21 Javascript
node中的密码安全(加密)
2018/09/17 Javascript
vue-cli基础配置及webpack配置修改的完整步骤
2019/10/20 Javascript
基于javascript实现贪吃蛇小游戏
2019/11/25 Javascript
Angular5整合富文本编辑器TinyMCE的方法(汉化+上传)
2020/05/26 Javascript
JS实现按比例缩小图片宽高
2020/08/24 Javascript
Python合并字典键值并去除重复元素的实例
2016/12/18 Python
使用python中的in ,not in来检查元素是不是在列表中的方法
2018/07/06 Python
Python+OpenCV目标跟踪实现基本的运动检测
2018/07/10 Python
Python爬虫实现验证码登录代码实例
2019/05/10 Python
解决tensorflow添加ptb库的问题
2020/02/10 Python
关于Tensorflow 模型持久化详解
2020/02/12 Python
python实现低通滤波器代码
2020/02/26 Python
如何在Win10系统使用Python3连接Hive
2020/10/15 Python
CSS3属性 line-clamp控制文本行数的使用
2020/03/19 HTML / CSS
VICHY薇姿俄罗斯官方网上商店:法国护肤品牌,火山温泉水
2019/11/22 全球购物
银行会计职员个人的自我评价
2013/09/29 职场文书
党风廉政承诺书
2014/03/27 职场文书
一年级学生期末评语
2014/04/21 职场文书
建筑横幅标语
2014/10/09 职场文书
不同意离婚上诉状
2015/05/23 职场文书
vite+vue3.0+ts+element-plus快速搭建项目的实现
2021/06/24 Vue.js
什么是clearfix (一文搞清楚css清除浮动clearfix)
2023/05/21 HTML / CSS