Power Pivot 系列 (2) - 动态数据透视表和透视图

本篇接着介绍 Power Pivot,使用上一篇的数据,编制一个透视表 + 透视图,实现数据动态展示,动态效果来自切片器 (slicer)。其实切片器并不是 Power Pivot 而是 Excel 的功能,在 Excel 中表格和数据透视表都能用到切片器。但鉴于切片器的作用,所以也在 Power Pivot 系列中对切片器作一些介绍。。

本篇要实现的最终界面如下:



最左边和最上边使用两个切片器实现动态筛选:按年份和按产品类别。主体部分的左边部分是按品牌统计销售数量和销售金额,右边是按季度统计。上一篇我已经解释了 Power Pivot 多个表建立连接之后数据透视表能在多个表中自由选择字段进行分析,所以按品牌来编制数据透视表已经没有问题,但按年度筛选,按按季度分析,需要先对数据进行进一步加工。

Power Pivot 添加列

进入 Power Pivot 界面,切换到 SalesOrder 表,选中最右边「添加列」任意一个单元格,然后将光标放到公式栏编写公式,这个跟 Excel 工作表界面非常类似:

然后在公式栏中输入:

= YEAR([TxDate])

像下面这样:


然后回车,这样就创建了一个新列,对新列重命名为 TxYear。使用 MONTH() 函数添加另一个计算列 TxMonth:


介绍一下 Power Pivot 字段的语法。Power Pivot 的表 (table) 用单引号包含,比如 'SalesOrder'。如果表名称没有空格,也可以省略单引号;Power Pivot 的字段用中括号包含,比如 [TxDate]。引用其他表的字段需要用完全标识符 (full-qualified identifier),比如 'Products'[CategoryName]。在公式栏或度量值输入的时候,可以输入单引号或中括号,Power Pivot 在输入单引号或中括号后,给出表或字段的智能提示,能帮助公式输入。

但 Power Pivot 并没有直接获取季度的函数,可以用 FORMAT() 函数,根据日期来获得季度值:

TxQuarter = VALUE(FORMAT([TxDate], "Q"))

Format 函数的第二个参数值为 Q 表示返回季度, FORMAT()函数的返回值是文本型,所以再用 VALUE 函数转换为数字。

添加数据透视图

回到 Excel 工作表,通过下面的菜项添加 一个新的数据透视图:


图例选择 Products 表的 BandName,选择 SalesOrder 表的 SalesAmount ,计算类型使用合计


此时得到的数据透视图如下,因为品牌比较多,最初的格式不太美观,需要进行美化。


现在值字段显示为「以下项目的总和:SalesAmount」,我们可以在值字段设置(右键菜单)调出下面的对话框进行修改。将值字段改为:销售总额:

这个是 Excel 数据透视表就有的功能,Power Pivot 中有一个更好的方法:度量值。什么是度量值呢?可以简单的理解为基于字段的计算值,但这个计算值非常灵活,能根据相关的条件(称为上下文)对参与计算的数据进行筛选。

再进入 Power Pivot 界面,下图红线标记的部分就是建立度量值的区域:


选中 SalesAmount 列任意单元格,或者选中整列,然后在【主页】选项卡中点击【自动汇总】下拉框,选择求和项,这样就建好了一个度量值。

这个新添加的度量值,在公示栏显示公式,在 SalesAmount 列下面的度量值区域显示了计算的结果:


在公示栏将度量值的名称改为:销售额:

销售额:=SUM([SalesAmount])

同样的方法添加一个度量值:销售数量,对 Qty 字段进行求和。

销售数量:=SUM([Qty])

回到 Excel 界面,此时数据透视图字段面板中,在 SalesOrder 表下面,多了两个字段,前面有 fx 标识,这就是新添加的两个度量值。


销售额度量值拖到值字段中,这个时候数据透视图的效果与前面将 SalesAmount 拖到值字段类似,但值字段在透视图中也显示为销售额,而不是「以下项目的总和:SalesAmount」。

接下来插入两个切片器:年度和产品类别。选中数据透视图,Excel 自动出现【数据透视图分析】选项卡,点击【插入切片器】菜单:

选择 Products 表的 CategoryName 和 SalesOrder 表的计算字段 TxYear,将这两个字段作为切片器。

可以对切换器的样式、列数和标题等进行修改。我门对两个切片器都改变标题,拖到合适的位置。在选中切片器的时候,Excel 自动出现【切片器】选项卡,在这里设置切片器的样式以及切片器列的数量。


透视图左边 y 轴 数据精确到个位,可以改为以千元显示。方法是选中左边 y 轴,右键,选择设置坐标轴格式菜单,右边出现设置面板。将数字的类别设为「自定义」,将格式代码改为 #,##0, 然后点击添加按钮:

数据就变成千元显示格式了:


可以用同样的方法添加一个按季度分析的数据透视图,但更简单的做法是从已经添加的数据透视图复制一个,再进行修改。我用复制的方法,很快添加第二个数据透视图如下:


在数据透视图的下面添加两个数据透视表(操作参照上一篇),调整大小和位置,得到最终的输出效果。

将切换器连接到报表

添加的切换器,并不是自动连接到所有数据数据透视表和数据透视图,如果没有关联,选中切片器后,在自动出现的【切片器】选项卡中,点击【连接报表】菜单进行设置。

示例数据

Github - Dynamic Pivot using Slice

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,417评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,921评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,850评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,945评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,069评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,188评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,239评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,994评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,409评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,735评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,898评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,578评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,205评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,916评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,156评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,722评论 2 363
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,781评论 2 351

推荐阅读更多精彩内容