Tableau | 桑基图(Sankey)

下载练习工作簿:https://public.tableau.com/zh-cn/s/gallery/charts-visualizing-funnel-or-pipeline?tab=viz-of-the-day&type=viz-of-the-day

桑基图(Sankey),又叫桑基能量分流图,也叫桑基能量平衡图。第一,该图遵守“能量守恒”或者说“数量守恒”。这个图常见的使用场景如下图所示,用于分析用户行为流,我们通过这个图可以看到用户从哪儿来到哪儿去,这样我们可以分析出来,用户的行为路径是否与我们设想的行为流程一致,看在哪一个页面哪一个操作,用户的跳出率最高,从而去优化产品。

桑吉图示例

基础数据源:

构建桑基图步骤

1、将数据复制一份,加到表的底部,并将添加一列,命名为Table name,第一部分该字段的值填充为“Sankey”,第二部分填充为“Sankey1”

2、添加计算字段,命名为“S Bin Min Max”,该字段定义如下:

if [Table Name] = 'Sankey' then 1

elseif [Table Name] = 'Sankey1' then 51*2 + 1

end

说明:这个字段是为了规定数据桶的最大最小值,其中103作为显示标签的占位。

3、根据“S Bin Min Max”创建数据桶,命名为“S(bin)”

s bin 数据桶

4. 创建索引函数,命名为S Index=index()

5. 添加辅助字段

① Total Count=WINDOW_MAX(MAX([Input Number]))

说明:这个字段用来计算每个状态对应的总量,Input Number在本案例中是一个输入参数,用来调节每个状态的值。在你实际运用时,这个值可能是不同步骤的用户数,不同状态的订单数等。

② Lookup1=LOOKUP([Total Count],-1)

说明:寻找当前值的前一个值

③ Lookup2=LOOKUP([Total Count],-2)

说明:寻找当前值的前二个值

5. 创建计算字段X,这个X字段用于生成X轴的坐标

if [S Index]=103

  then 0

else

  (

    (if [S Index]-1 < 51

        then [S Index]-1

      else 101 - [S Index]+1

      end

    )

    * 2 * 0.12

  ) - 6

end

6.添加Y字段

if [S Index] < 103 then

if window_max(max([Type])) = 'In Process'

  then

    iif([S Index] < 52, 0, [Total Count])

// 当[S Index] < 52的时候,Y=0,[S Index]=52-102时,Y= [Total Count]

elseif window_max(max([Type])) = 'Terminated'

  // 当 Type+Terminated的时候开始画线

  then

    if [S Index] < 52 then  

        1 /(1+exp(-[X])) * [参数].[Curve Height] 

// 开始画线了,先画上边的线

    else  // 再画上边的线

        (1 /(1+exp(-[X])) * [参数].[Curve Height])+([Total Count])

    end

    +[Lookup1] //为了与前一部分的内容链接起来,则让其等于上个值

else

//将其他步骤的terminated的值承接

    iif([S Index] < 52, 0,[Total Count])

    +[Lookup1]+[Curve Height]

    +[Lookup2]

end

end

6. 制作桑吉图,将所需字段按图示拖拽到相应的位置

桑吉图制作步骤

7、X和Y表计算的配置

X:

X 表计算配置

Y:

因为我们在计算Y的时候,嵌套了多个表计算,所以现在依次来配置

① S index

S index 配置

②Total Count

Total count

③Lookup1

Lookup1

④Lookup2

Lookup2

你可能感兴趣的:(Tableau | 桑基图(Sankey))