Hive split如何截取字符串,获取最后一部分?

2026-04-11 03:252阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计350个文字,预计阅读时间需要2分钟。

Hive split如何截取字符串,获取最后一部分?

问题背景:在处理一些字符串的时候,日常会遇到需要用到split函数的情况。split函数的处理结果是数组类型,然后可以在获取数组中的对应元素。

具体操作:当我们获取最后一部分字符串时,可以使用split函数,格式为split(string, str)。

问题背景

日常在处理一些字符串的时候,需要用到split函数,split的处理结果是array类型,然后在获取数组中对应的元素。

Hive split如何截取字符串,获取最后一部分?

我们在获取最后一部分字符串的时候使用split(string str, string pat)[-1] 的时候会报错,不能使用[-1]获取对应位置的元素,我找到了下面两种方案。

  • 使用size函数获取数组长度

-- 比如截取a_b_c_Wave2_d-S3,按照'_'截取获取最后一个字符串d-S3 select size(split('a_b_c_Wave2_d-S3','_')); --结果是5 select split('a_b_c_Wave2_d-S3','_')[size(split('a_b_c_Wave2_d-S3','_'))-1];--得到结果d-S3

  • 使用reverse函数翻转字符串

-- 比如截取a_b_c_Wave2_d-S3,按照'_'截取获取最后一个字符串d-S3 select reverse('a_b_c_Wave2_d-S3'); --结果3S-d_2evaW_c_b_a select split(reverse('a_b_c_Wave2_d-S3'),'_')[0]);--结果3S-d select reverse(split(reverse('a_b_c_Wave2_d-S3'),'_')[0]);--结果d-S3

结果总结:两种方式都能够获得我们需要的字符串,等发现有什么异常点的时候再更新

本文共计350个文字,预计阅读时间需要2分钟。

Hive split如何截取字符串,获取最后一部分?

问题背景:在处理一些字符串的时候,日常会遇到需要用到split函数的情况。split函数的处理结果是数组类型,然后可以在获取数组中的对应元素。

具体操作:当我们获取最后一部分字符串时,可以使用split函数,格式为split(string, str)。

问题背景

日常在处理一些字符串的时候,需要用到split函数,split的处理结果是array类型,然后在获取数组中对应的元素。

Hive split如何截取字符串,获取最后一部分?

我们在获取最后一部分字符串的时候使用split(string str, string pat)[-1] 的时候会报错,不能使用[-1]获取对应位置的元素,我找到了下面两种方案。

  • 使用size函数获取数组长度

-- 比如截取a_b_c_Wave2_d-S3,按照'_'截取获取最后一个字符串d-S3 select size(split('a_b_c_Wave2_d-S3','_')); --结果是5 select split('a_b_c_Wave2_d-S3','_')[size(split('a_b_c_Wave2_d-S3','_'))-1];--得到结果d-S3

  • 使用reverse函数翻转字符串

-- 比如截取a_b_c_Wave2_d-S3,按照'_'截取获取最后一个字符串d-S3 select reverse('a_b_c_Wave2_d-S3'); --结果3S-d_2evaW_c_b_a select split(reverse('a_b_c_Wave2_d-S3'),'_')[0]);--结果3S-d select reverse(split(reverse('a_b_c_Wave2_d-S3'),'_')[0]);--结果d-S3

结果总结:两种方式都能够获得我们需要的字符串,等发现有什么异常点的时候再更新