大数据之Hive:parse_urlparse_url_tuple函数

Posted 浊酒南街

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了大数据之Hive:parse_urlparse_url_tuple函数相关的知识,希望对你有一定的参考价值。

目录

前言

parse_url、parse_url_tuple 是hive内置函数,可以解析URL,区别在于,parse_url一次只能输出一个值,parse_url_tuple 可以输出多个值,parse_url_tuple 函数可以和LATERAL VIEW 搭配使用;

一、parse_url ()

解析URL字符串,partToExtract的选项包含[HOST,PATH,QUERY,REF,PROTOCOL,FILE,AUTHORITY,USERINFO]。
【host,path,query,ref,protocol,file,authority,userinfo】这些可以理解为关键字 通过关键字可以获得url中对应的字段数据
示例1:

select parse_url('https://www.baidu.com/hzy?user_id=10000&platform=ios','PROTOCOL');--https
select parse_url('https://www.baidu.com/hzy?user_id=10000&platform=ios','HOST');--www.baidu.com
select parse_url('https://www.baidu.com/hzy?user_id=10000&platform=ios','PATH');--/hzy
select parse_url('https://www.baidu.com/hzy?user_id=10000&platform=ios','QUERY');--user_id=10000&platform=ios
select parse_url('https://www.baidu.com/hzy?user_id=10000&platform=ios','QUERY','user_id');--10000
select parse_url('https://www.baidu.com/hzy?user_id=10000&platform=ios','QUERY','platform');--ios
select parse_url('user_id=10000&platform=ios','QUERY');--null

示例2:

select parse_url(concat('https://www.baidu.com/?','user_id=10000&platform=ios'),'QUERY','user_id');--10000
select parse_url(concat('https://www.baidu.com/?','user_id=10000&platform=ios'),'QUERY','platform');--ios

二、parse_url_tuple()

语法: parse_url(string urlString, string partToExtract [, string keyToExtract]),parse_url_tuple功能类似parse_url(),但它可以同时提取多个部分并返回
    返回值: string
    说明:返回URL中指定的部分。partToExtract的有效值为:HOST, PATH, QUERY, REF, PROTOCOL, AUTHORITY, FILE, and USERINFO.
示例1:

select parse_url_tuple("http://www.baidu.com/find?cookieid=4234234234",'HOST','PATH','QUERY','QUERY:cookieid');
--c0 c1 c2 c3 
--www.baidu.com /find cookieid=4234234234 4234234234

示例2:

with temp as
    (select "https://www.baidu.com/hzy?user_id=10000&platform=ios" as url )
--select * from temp;
SELECT b.*
FROM temp
LATERAL VIEW parse_url_tuple(url, 'HOST', 'PATH', 'QUERY', 'QUERY:user_id', 'QUERY:platform') b
as host, path, query, user_id ,platform;
--host path query user_id  platform
--www.baidu.com /hzy user_id=10000&platform=ios 10000 ios

参考链接:https://blog.csdn.net/zengxianglei/article/details/89969144

以上是关于大数据之Hive:parse_urlparse_url_tuple函数的主要内容,如果未能解决你的问题,请参考以下文章

框架梳理|企业大数据管理之道

大数据技术之大数据概论

淘宝大数据之流式计算

大数据技术之大数据概论

大数据开发之linux平台基础

大数据之学习之路