学会就能效率翻倍的数组公式,到底怎么用?

可乐的数据分析之路

1、什么是数组公式

在研究数组公式前,先要明确什么是数组?

数组嘛,可以理解为若干相同数据的组合

比如{1,2,3,4}是数值组合在一起,{"c";"o";"l";"a"}是字符的组合,这种只有1行的数组是横向数组,1列的是垂直的数组,他们是一维数组。多行多列的是二维数组。


image

那什么是数组公式呢?

Excel里会看到带大括号的公式{},就是数组公式,但这个大括号不是手动加上去的,而是输入公式后同时按下ctrl+shift+enter后自动带的。比如下图将数组1和数组2相加。
[图片上传失败...(image-2443dd-1619015560800)]

2、数组的计算

理解并且创建了数组以后,要思考如何计算数组,数组公式当然也就是计算数组的公式。

  • 举个栗子

比如要求总销售额,等于单价乘以销售数量,求一个产品的销售额,=C2*D2

如果要求很多产品的销售额,当然,可以直接把公式往下拖,但我们也可以换个思路,就是用数组公式。

选择F2:F11区域,输入=C2:C11*D2:D11,然后同时按下ctrl+shift+enter键


在这里插入图片描述

这里,用数组公式的好处是

  • 假如数据量很多,可以避免使用普通公式拖动的情况
  • 文件小,数组公式只有一个公式,F2和F11都是一个公式,但普通公式从F2到F11拥有10个不同的公式,如C2D2,C11D11

另外,数组公式求总计和用sumproduct公式是一个原理,但和sum就很不一样了,比用sum方便许多。


image

通过上面的栗子,我们知道了数组计算的过程:

  1. 首先要选定区域
  2. 然后输入公式
  3. 最后同时按下ctrl+shift+enter键

我们可以再系统地理解一下数组的计算

2.1 数组和单值的计算

对数组1{1,2,3,4}乘以2,是对数组中的每个元素都乘以2,首先选中A5:D5区域,然后输入=A2:D2*2 ,同时按下ctrl+shift+enter键完成数组运算,结果如图得到{2,4,6,8}


image

2.2 一维数组和一维数组的计算

第一小节说,数组有一维和二维之分,并且还有方向的区别。

- 同方向一维数组的计算

两个横向的一维数组的计算,就是元素对应相加即可。

数组1+数组2,选中A8:D8区域,输入=A2:D2+A5:D5,同时按下ctrl+shift+enter键完成数组运算,结果如图得到{6,8,10,12}


image

元素不对应怎么办?

如下图,数组1是4个元素,数组2是5个元素,数组1缺了一个元素和数组2的9相加,如果还硬要选择A11:E11区域的话,系统就只能用缺失值代替了。


image

- 不同方向的一维数组的计算

一个横向的X列一维数组和一个垂直的Y行一维数组计算的结果是,一个X列Y行的二维数组。

比如数组3是含有4个元素4列,数组4是含有3个元素的3行,他们相加,结果是一个3行4列的二维数组。

其中的原理是这样的,数组3可以看成3行4列的一个二维数组,数组4也可以看成是一个3行4列的二维数组,将其中的元素一一对应相加就得到了数组3数组4的结果。


image

2.3 一维数组和二维数组的计算

一个一维数组和一个二维数组计算

有了2.2的不同方向的一维数组计算的原理,我们其实明白了,数组间的计算首先还是要把它们调到同一个频道上,比如数组4和数组5相加,可以把数组4看成是一个3行2列的二维数组再和同纬度的数组5相加,就可以一一对应了。

image

2.4 二维数组和二维数组的计算

二维数组间的计算,就更好理解了,直接两两对应计算即可,对应不上的,就用缺失值填充。

如数组5和数组6相加


image

3、数组公式可以解决什么问题

Excel已经有很多公式了,为什么我们还要学数组公式呢?数组公式可以解决什么问题呢?

相比于普通公式,数组公式可以:

  • 快速创建示例数据集
  • 对包含错误值的区域进行计算
  • 条件计算

3.1 创建数据集

使用逗号分隔各个项,将创建水平数组(一行)。

选择A1:C1单元格,输入={1,2,3},然后同时按下ctrl+shift+enter键,Excel 使用大括号 ({ }) 将公式括在选定区域的每个单元格中,得到A1=1,A2=2,A3=3的结果。


在这里插入图片描述

使用分号分隔项,将创建垂直数组(一列)。


在这里插入图片描述

若要创建二维数组,应在每行中使用逗号分隔项,并使用分号分隔每行。
image

3.2 对包含错误值的区域计算

当对包含错误值(例如 #N/A)的区域求和时,SUM 函数不起作用。那么如何对包含错误的区域求和或求平均、计数等一系列数值运算的操作呢?就可以用数组公式。

如下图单价中包含一个错误值#N/A,直接用average函数是计算不出平均值的,输入=AVERAGE(IF(ISERROR(D2:D11),"",D2:D11)),同时按下ctrl+shift+enter键完成数组运算。

ISERROR(D2:D11)是判断D2:D11区域有无错误值,有的话返回TRUE,没有返回FALSE

IF(ISERROR(D2:D11),"",D2:D11),IF函数再来判断,有错误值时(也就是为TRUE时)返回一个空值“”,没有错误值(FALSE)时返回自己所在的区域。这样错误值就被空值“”避免了,也就可以计算了。


image

3.3 条件计算

比如上节内容:
Excel里关于if的9个函数,如何指定条件求和、计数、平均等

里最后提到的用数组公式计算不同条件下数值的标准差。

输入=STDEV(IF(A:A=D2,B:B,"")),然后ctrl+shift+enter 一起按,这个数组公式的意思是,如果A列的值等于D2单元格,那么值区域就等于D2单元格对应的值,否则就为空,接着对值区域求标准差。如果用dstdev公式还需要自己构建条件区域,数组公式就方便一点。


image

还可以计算深圳和广州的平均分,输入公式=AVERAGE(IF(A:A=D2,B:B,"")),再同时按下ctrl+shift+enter键,得到的结果和我们用averageif算的是一样的,这个数组公式的意思是,如果D列的值等于D2单元格深圳,那么值区域就是深圳对应的得分,否则就为空,然后再对值区域求平均。


image

数组公式有好处,但是也有缺点,比如:
  • 不可更改,单个单元格无法更改,若要更改,需要整体处理,这也可以当成优点,安全!
  • 大型数组公式可能会降低计算速度,具体取决于计算机的处理速度和内存。

看到这,你学会用数组公式了吗?

任何疑问欢迎交流:data_cola
可乐的数据分析之路

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

推荐阅读更多精彩内容