跳到主要内容
版本:5.9.0

字段拆分案例分享

需求背景

数据集中有字段结构为用分隔符连接起来的字符串,使用时需要拆分开只提取固定位置的字符串,或者整体拆分为多列。

案例场景

案例一:新建计算字段,使用字符串截取函数,定位分隔符位置从而进行拆分。

image.png

  1. 实际路线起始点:取第一个横杠之前字符串。
SUBSTR([实际路线],0,INSTR([实际路线],'-')-1)  或者 left([实际路线],INSTR([实际路线],'-')-1)

image.png

  1. 实际路线剩余部分:1和2能够拼接回完整的路线。
SUBSTR([实际路线],INSTR([实际路线],'-')+1)

image.png

  1. 实际路线到达点
right([实际路线],instr(REVERSE([实际路线]),'-')-1)

image.png

  1. 实际路线剩余前半部分:3和4能够拼接回完整的路线。
REGEXP_EXTRACT([实际路线],'(.+)(-{1}.+)',1)

image.png

  1. 到达点是否是工厂:工厂的判断规则是纯字母,且结尾不是DC。
when SUBSTR([实际路线到达点],-2)<>'DC' and (SUBSTR([实际路线到达点],0,1)  <='Z' AND 'A'<= SUBSTR([实际路线到达点],0,1))
then '是'
when [实际路线到达点] is null or [实际路线到达点] = ''
then '否'
else '否'
end

image.png

  1. 到达点是否是WS:WS的判断标准是纯汉字,无其他字母、数字。
when SUBSTR([实际路线到达点],-2)='DC' or (SUBSTR([实际路线到达点],0,1)  <='Z' AND 'A'<= SUBSTR([实际路线到达点],0,1))
then '否'
when [实际路线到达点] is null or [实际路线到达点] = ''
then '否'
else '是'
end

image.png

  1. 到达点拆分

示例:
实际路线=BAD-沧州_沧县_忤龙堂
实际路线到达点=沧州_沧县_忤龙堂
到达点模糊处理1=沧州_沧县
到达点模糊处理2=沧州

-- 到达点模糊处理1
REGEXP_EXTRACT([实际路线到达点],'(.+)(_{1}.+)',1)
-- 到达点模糊处理2
case when INSTR([实际路线到达点],'_')>0 then SUBSTR([实际路线到达点],0,INSTR([实际路线到达点],'_')-1) end

image.png

案例二:新建计算字段,把原字段用分隔符拆分为数组,定位数组元素位置从而进行拆分。

image.png

  1. 拆分为 array:split([字段],'-')**

image.png

  1. 去除结尾部分:array_join(slice([分割字符],1,size([分割字符])-1),'-')
    拆分字段 1:array_join(slice([分割字符],1,1),'')
    拆分字段 2:array_join(slice([分割字符],2,1),'')
    结尾部分:array_join(slice([分割字符],size([分割字符]),1),'')

image.png

【注意】:以上函数可以用于 ETL 和非直连非加速数据集,直连数据集请使用对应数据库函数,高性能(加速)数据集需要使用 Clickhouse函数。

案例三:截取字符串中文/英文部分

image.png

实现方法:可以通过新加字段使用 正则表达式来实现

  1. 保留中文:

image.png

  1. 保留英文:

image.png

最终结果:

image.png