代码改变世界

QlikView ETL - 分隔字符串的方法 SubField

2015-02-27 15:31  BIWORK  阅读(2545)  评论(2编辑  收藏  举报

开篇介绍

今天在使用 QV 加载数据的时候会碰到列中的一些状态,信息是通过;或者 / 等符号分隔的,这样不利于做数据分析,因为字符串中的内容本身就是维度。上网搜了一下找到了解决的方法,记录一下。

比如第一幅图中 S200,M250,R35 都是 Invoice 的类型,这时都需要取出来作为分析的维度 DIMENSION。

可以通过下面的代码来实现上图的分隔效果,取出所有的 Invoice 类型,这样就可以做数据统计分析了。当然,其它的列会出现重新数据,在聚合的时候注意就好了。

代码

Source:
Load * Inline 
[ ID , Invoice 
  1  , S200/M250/R35/
  2  , M1687/A35/D879/F689/
  3  , B33625/S55/
] ;

Destination:
Load ID , 
     NewInvoice
Where Len ( NewInvoice ) > 0;
Load
    ID ,
    Invoice ,
    SubField( Invoice,'/') AS NewInvoice
;
Load * Inline 
[ ID , Invoice 
  1  , S200/M250/R35/
  2  , M1687/A35/D879/F689/
  3  , B33625/S55/
] ;

更多 BI 文章请参看 BI 系列随笔列表 (SSIS, SSRS, SSAS, MDX, SQL Server) 如果觉得这篇文章看了对您有帮助,请帮助推荐,以方便他人在 BIWORK 博客推荐栏中快速看到这些文章。