IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 传入一份excel,使用python代码生成hive建表语句,快速建hive表格 -> 正文阅读

[大数据]传入一份excel,使用python代码生成hive建表语句,快速建hive表格

如果我要建一个如下的hive表:
在这里插入图片描述
我可以使用下面的hive代码:

drop table if exists analyst.t_window;
create table analyst.t_window as select * from ( 
select 'jack' as name, '2015-01-01' as orderdate, 10 as cost
 union all 
select 'tony' as name, '2015-01-02' as orderdate, 15 as cost
 union all 
select 'jack' as name, '2015-02-03' as orderdate, 23 as cost
 union all 
select 'tony' as name, '2015-01-04' as orderdate, 29 as cost
 union all 
select 'jack' as name, '2015-01-05' as orderdate, 46 as cost
 union all 
select 'jack' as name, '2015-04-06' as orderdate, 42 as cost
 union all 
select 'tony' as name, '2015-01-07' as orderdate, 50 as cost
 union all 
select 'jack' as name, '2015-01-08' as orderdate, 55 as cost
 union all 
select 'mart' as name, '2015-04-08' as orderdate, 62 as cost
 union all 
select 'mart' as name, '2015-04-09' as orderdate, 68 as cost
 union all 
select 'neil' as name, '2015-05-10' as orderdate, 12 as cost
 union all 
select 'mart' as name, '2015-04-11' as orderdate, 75 as cost
 union all 
select 'neil' as name, '2015-06-12' as orderdate, 80 as cost
 union all 
select 'mart' as name, '2015-04-13' as orderdate, 94 as cost) t

现在只要传入一份含有hive表数据的excel,使用下面python源代码便可以快速生成以上hive代码,再将这份hive代码拷贝到hive平台就可以建hive表了。直接上python代码:

import pandas as pd
def dfToSql(df, table_name='tmp_table', t='d'):
    '''
    输入:
        DataFrame
        表名
        t: c for create, o for overwrite, d for default
    输出:用union all拼接的建表语句
        select 'xx' as xx, 'xx' as xx
        union all
        select 'xx' as xx, 'xx' as xx
    '''

    def isStr(row):
        res = 'select '
        last_col = list(row.index)[-1]
        print(row.index)
        for i in row.index:
            if isinstance(row[i], int) or isinstance(row[i], float):
                if i != last_col:
                    res += "{} as {}, ".format(row[i], i)
                else:
                    res += "{} as {}".format(row[i], i)
            else:
                if i != last_col:
                    res += "'{}' as {}, ".format(row[i], i)
                else:
                    res += "'{}'as {}".format(row[i], i)
        return res

    duohang = df.apply(lambda row: isStr(row), axis=1) # 关键句
    sql = "\n union all \n".join(duohang) #duohang的类型是 Series类型
    sql = sql.replace('nan', '')

    if t == 'c':
        head = 'drop table if exists {};\ncreate table {} as select * from ( \n'.format(table_name, table_name)
    elif t == 'o':
        head = 'insert overwrite table {} select * from ( \n'.format(table_name)
    elif t == 'd':
        head = 'select * from ( \n'
    tail = ') t'
    res = head + sql + tail
    return res


df = pd.read_excel('ceshi.xlsx') #将excel表名放在这里

sql = dfToSql(df, 'analyst.fiona_20210802_liupu', 'c') # 填写上你即将要建的hive表的表名
sql_2 = sql.replace('-1', 'null')

with open('res.txt', 'w+', encoding='utf-8') as f:  # res.txt就是你要拷贝到hive里进行建表的hive代码
    f.write(sql_2)

这个是Series类型的final:
在这里插入图片描述

下面我用一份更加简单的代码来解释上面的代码:

import pandas as pd
import numpy as np

df = pd.DataFrame(np.random.randn(4, 3), columns=list('bde'), index=['utah', 'ohio', 'texas', 'oregon'])


def te(x):
    print(x) # Name: oregon, dtype: float64
    # '''
    #    b   -0.878668
    #    d   -0.213281
    #    e    0.946508
    # '''
    # print(x.index)  # Index(['b', 'd', 'e'], dtype='object')
    # print(x.index[1])  # d
    # print(x['b'])  # -0.8786
    res = ''
    for i in x.index:
        if i != x.index[-1]:
            res += 'select {} as {},'.format(x[i], i)
        else:
            res += 'select {} as {}'.format(x[i], i)
    return res


final = df.apply(lambda x: te(x), axis=0)
'''
apply默认是一列列输入,这里用了axis=1就是变成一行行输入
如果没有加axis=1,那上面的x.index就是Index(['utah', 'ohio', 'texas', 'oregon'], dtype='object')
很简单的,就是一个索引
'''
print(type(final)) # final是series类型
'''
join的使用办法
li = ['a', 'b', 'r', 'we']  # list可以用join  Series类型也可以用join
str = '-'
sql1 = str.join(li)   结果为:a-b-r-we
'''
str = '\n union all \n'
sql = str.join(final)

with open('D:/wow.txt', 'w') as f:
    f.write('sql:')
    f.write(sql)

这个是df:
在这里插入图片描述

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-08-20 15:11:21  更:2021-08-20 15:12:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 17:54:46-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码