hive科学计数法转字符串_hive 科学计数法转字符串-程序员宅基地

技术标签: hive  hive学习  

科学计数法转字符串

20191014


有时需要将表里的int, double, float转为string类型的(主要的是int),但有时int在hive里是用科学计数法来表示的,不能直接转string.参考文章【链接】.

  • 对于int类型,可以直接先转为bigint再转为stringcast(cast(intnum bigint) as string)

  • 对于一般类型可用下面的语句(不是我写的0-0,但可以顺便学习了下hive里的正则表达式,记录一下)

--处理非科学计数法表示的字符串
--变量 :${hivevar:bignum}
select 
case
--处理非科学计数法表示的字符串
when length(regexp_extract('${hivevar:bignum}','([0-9]+\\.)([0-9]+)(E-*[0-9]+)',2)) = 0
then '${hivevar:bignum}'
--处理整数
when length(regexp_extract('${hivevar:bignum}','([0-9]+\\.)([0-9]+)(E[0-9]+)',2)) <= cast(regexp_extract('${hivevar:bignum}','(E)([0-9]+)',2) as int)
then rpad(regexp_replace(regexp_extract('${hivevar:bignum}','([^E]+)',1),'\\.',''),cast(regexp_extract('${hivevar:bignum}','(E)([0-9]+)',2) as int)+1,'0')
--处理小数
when length(regexp_extract('${hivevar:bignum}','([0-9]+\\.)([0-9]+)(E[0-9]+)',2)) > cast(regexp_extract('${hivevar:bignum}','(E)([0-9]+)',2) as int)
then concat(substr(regexp_replace(regexp_extract('${hivevar:bignum}','([^E]+)',1),'\\.',''),1,cast(regexp_extract('${hivevar:bignum}','(E)([0-9]+)',2) as int)+1),'\.',
substr(regexp_replace(regexp_extract('${hivevar:bignum}','([^E]+)',1),'\\.',''),cast(regexp_extract('${hivevar:bignum}','(E)([0-9]+)',2) as int)+2))
--纯小数,处理类似“3.4E-6”这种字符串
when ${hivevar:bignum} regexp 'E-'
then concat('0.',repeat('0',cast(regexp_extract('${hivevar:bignum}','(E)(-)([0-9]+)',3) as int)-1),regexp_replace(regexp_extract('${hivevar:bignum}','(.+)(E)',1),'\\.',''))
else '${hivevar:bignum}'
end

参考

参考链接.

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/hujunyin/article/details/102541508

智能推荐

X-code 常用操作_x-code评级怎么做-程序员宅基地

文章浏览阅读1.5k次。新建项目command+shift+n切换双屏command+shift+enter_x-code评级怎么做

filebeat使用_filebeat单独使用-程序员宅基地

文章浏览阅读569次。为了充分利用elasticsearch的检索,及速度快; kibana的界面自动抽象,及交互能力,我们使用filebeat获取数据,如日志等,发送到elastic.暂时没有使用logstash,根据文献,就是它多了一个filter的功能,还要转一道,暂时不用。另修改var.path可以确定你要filebeat的日志的路径 。 记得enable:true.//todo : 还有一个f..._filebeat单独使用

Unix和Linux有什么区别?_unix和linux的区别-程序员宅基地

文章浏览阅读4.8k次。什么是Linux?Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和Unix的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的Unix工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。Unix和Linux有什么区别?Linux和Unix都是功能强大的操作系统,..._unix和linux的区别

Cisco跨vlan通信------单臂路由_g0/1口分成g/0.1和g0/0.2这是什么-程序员宅基地

文章浏览阅读1k次。拓扑如下:其中g0/0.1与g0/0.2是基于g0/0口(物理端口)的虚拟端口,又称子接口,若g0/0口坏掉,则其均不能工作。注意:encapsulation dot1Q 10 为封装协议,其中10要与Vlan号一样,即vlan10的网关要封装dot1Q 10,vlan20封装dot1Q 20,以此类推。PC1: ..._g0/1口分成g/0.1和g0/0.2这是什么

【CAS】Flask客户端配置_flask cas-程序员宅基地

文章浏览阅读3.7k次。CAS服务端配置,看这里本文基于Flask-CAS作为客户端与CAS服务端调试,测试多属性返回信息。1 环境说明Flask-CAS: 1.0.1Flask: 1.0.22 客户端工程目录#!/usr/bin/env python# -*- coding: utf-8 -*-"""__title__ = ''"""import sslimport flas..._flask cas

动手实现天气预报App(一)——数据、工具类和碎片布局准备_android 第一行代码 weather?cityid=1&key=bc0418b57b24918-程序员宅基地

文章浏览阅读979次。文章目录需求分析数据来源创建数据库和表加载全国省市区数据请求和解析数据工具类碎片界面布局加载数据碎片逻辑测试本系列记录一下跟随guolin大神学习的项目自己完成一个天气预报Android App.需求分析可以列出全国所有省市县可以查看全国任意城市天气信息可以自由切换城市,查看不同地区天气有手动刷新和后台自动更新天气功能数据来源郭神提供的数据接口,包含全国省市县名称和编号信息:省级单位:http://guolin.tech/api/china服务器会返回JSON格式数据市级单位:_android 第一行代码 weather?cityid=1&key=bc0418b57b24918819d3974ac1285d9

随便推点

HDOJ1000A + B Problem_a + b problem time limit: 2000 msmemory limit: 655-程序员宅基地

文章浏览阅读351次。A + B ProblemTime Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 638167 Accepted Submission(s): 199263Problem DescriptionCalculat_a + b problem time limit: 2000 msmemory limit: 65536 kb calculate a + b input t

【CAD-Web】CAD/DWG的Web化_dwg web-程序员宅基地

文章浏览阅读2.2w次,点赞18次,收藏70次。一、背景近期需要做个信息系统,能将一些2D的平面示意图(DWG格式文件)放到Web上,供放大、浏览,甚至可对元素进行交互,如点击、拖动、改变元素颜色线条等。于是,需要寻找开源的解析DWG格式的项目或者软件,一路下来,很是辛苦。这里记录下搜索到的有用信息。二、DWG与DXFDWG格式文件是Auto CAD软件的专有格式,类似于doc,是封闭的不开放的,且是二进制的。而 DXF格式则..._dwg web

VS中qt的include文件报错无法打开源文件问题解决办法----无法打开源文件QtWidgets/QApplication_vs转成qt项目后,include打不开了-程序员宅基地

文章浏览阅读1.8k次。换了一台电脑,把以前的qt文件迁移过来,手贱改了下sdk版本,qt的头文件就全找不到了1.将sdk设为10.02.来回切换下qt版本3.重启ide_vs转成qt项目后,include打不开了

web项目中扫描枪的应用_asp web 扫描枪-程序员宅基地

文章浏览阅读1w次。1. 页面有个输入框2. 扫描枪要设置自动Enter,这个说明书上应该有的3. 页面JQuery代码:$(document).keydown(function(event) { var keyCode = event.keyCode; if(keyCode == "13"){ var value = $("#elementId"); _asp web 扫描枪

java计算机毕业设计街舞公司管理系统MyBatis+系统+LW文档+源码+调试部署-程序员宅基地

文章浏览阅读180次。java计算机毕业设计街舞公司管理系统MyBatis+系统+LW文档+源码+调试部署。springboot基于SpringBoot的婚庆策划系统的设计与实现。ssm基于vue框架的疫情防控知识在线答题系统设计与实现。ssm基于HTML的“牧经校园疫情防控网站”的设计与实现。springboot体育馆预定管理平台的设计与实现。JSP网上测试系统的研究与设计sqlserver。JSP影城管理系统的设计与实现sqlserver。ssm基于Java智能选课系统的设计与实现。

PADS VX2.8 过孔盖油与不盖油的设置方法_pads过孔盖油怎么设置-程序员宅基地

文章浏览阅读2.7k次。在大多数的PCB设计过程中,过孔都需要盖油。方法一:打开PADSlayout界面,点击“设置”→“焊盘栈”,在“焊盘栈特性”窗口,正常添加一个过孔并修改“名称”、“直径”、“尺寸”等信息,此时的过孔是默认盖油的,操作如下图所示:添加并配置好过孔后,点击“添加”,在弹出的“添加层”选择“Solder Mask Top”和“Solder Mask Bottom”(顶层或底层都可以添加,根据项目需要)并修改“直径”,不盖油一般要外扩4mil或0.1mm。不盖油的过孔操作如下图所示:..._pads过孔盖油怎么设置

推荐文章

热门文章

相关标签