ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 4448|回复: 4

[求助] EXCEL数组例题运算逻辑

[复制链接]

TA的精华主题

TA的得分主题

发表于 2014-3-17 09:15 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖已被收录到知识树中,索引项:VLOOKUP
本帖最后由 dengjq2000 于 2014-3-18 13:39 编辑

求助,本题给出了很多解题思路,但是小白我有一点不明白:就是  解法2(qlz110、yeatol简化)中我自己通过数组输入方式输入(以A部门为例)=SUM((B$7:B$15=G21)*VLOOKUP(C$7:E$15,G$10:H$13,2,)*C$6:E$6)形成数组以后,得到的是24,而答案却是21.4,经过我的研究,我发现答案框左边多了一列答案(A38),就是无背景颜色的那个,我发现原来原题解答的作者是将A38和B38同时选中创建的数组公式。
我想问:为什么要这么操作才能得到正确答案?这个逻辑思路和运算过程是怎么样的?


excel_优秀练习题(总结).zip (7.06 KB, 下载次数: 332)


点评

知识树索引项位于3楼、5楼  发表于 2014-3-18 14:48

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-3-17 12:54 | 显示全部楼层
没有人来解答吗?那只好自己顶了。

TA的精华主题

TA的得分主题

发表于 2014-3-17 16:46 | 显示全部楼层
本帖最后由 Bodhidharma 于 2014-3-17 17:00 编辑

這個看起來是某個題目的總結帖,建議樓主直接給出該帖連結,並在該帖底下提問
翻了一下找到了原帖:
[Excel 函数与公式] [开_95]考评综合评分(已总结)
基本上vlookup的第一參數不接受數組參數,因此在單一單元格直接輸入
  1. =SUM((B$7:B$15=G21)*VLOOKUP(C$7:E$15,G$10:H$13,2,)*C$6:E$6)
复制代码
會得出
  1. =SUM((B$7:B$15=G21)*VLOOKUP(C$7,G$10:H$13,2,)*C$6:E$6)
复制代码
的結果。這個問題目前在論壇中已有解決方式:
  1. =SUM((B$7:B$15=G21)*VLOOKUP(T(IF({1},C$7:E$15)),G$10:H$13,2,)*C$6:E$6)
复制代码


至於以多單元格數組公式輸入,可得出正確結果的原因有點複雜…主要是SUM函數在處理這種「不接受數組參數的函數」的時候,會將所有結果整合在一起


TA的精华主题

TA的得分主题

 楼主| 发表于 2014-3-18 12:44 | 显示全部楼层
Bodhidharma 发表于 2014-3-17 16:46
這個看起來是某個題目的總結帖,建議樓主直接給出該帖連結,並在該帖底下提問
翻了一下找到了原帖:
[Exc ...

太感谢楼上了!我想问问,能否进一步解释一下这个公式的逻辑吗?主要是Vlookup函数内部的嵌套不太理解。
1、IF({1},XX:XX)这个代表什么意思呢?主要是{1}在IF中代表什么意思?
2、T函数在这里代表什么?它不是返回文本吗?

TA的精华主题

TA的得分主题

发表于 2014-3-18 13:26 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
losxunuo 发表于 2014-3-18 12:44
太感谢楼上了!我想问问,能否进一步解释一下这个公式的逻辑吗?主要是Vlookup函数内部的嵌套不太理解。
...

這個問題涉及的知識點有點多,而且有點難度,不過你既然都有興趣研究競賽題,相信你應該有能力理解以下內容…

如我前面所講,vlookup的第一參數不支援數組形式,因此像vlookup({1,2},引用範圍,...)在內存中,返回的結果會等同於vlookup(1,引用範圍...)
但是piny大師後來發現,像vlookup和index這些不支援數組形式的函數,如果加了N+if(1...)或T+if(1...)的話,就會變成可以支援,不過原理不明
因此vlookup(N(if(1,{1,2},引用範圍,...)就可以返回正確的內存數組

相關的討論可見:
[分享] 为piny发现的INDEX+N+IF用法推波助澜

不過有一點要注意,就是N、T函數內的參數,如果是「引用」的話,只會返回引用最左上角的值
相關說明可見:
http://club.excelhome.net/forum.php?mod=redirect&goto=findpost&ptid=882343&pid=7189125

因此vlookup(T(if(1,{"良","中","优"...})),...)可以返回正確的內存數組
但是vlookup(T(if(1,C$7:E$15)),...)在T的部分,只會回傳C7,因此還是無法回傳正確的內存數組

因此必需要將C$7:E$15這個「引用」,變成由文字所組成的「數組」
if(1,C$7:E$15)會直接返回C$7:E$15這個「引用」,但是if({1},C$7:E$15),因為第一參數是數組形式
因此會將C$7:E$15轉為{"良","中","优"...}這個數組,避開T函數只取最左上引用的問題
相關討論可見:
[讨论] IF({1} 与 IF(1 的区别


以上三個連結的內容都有一定難度,請小心服用
希望我以上說明講的夠清楚,如果有其它問題歡迎繼續討論~

评分

1

查看全部评分

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-12-21 23:44 , Processed in 0.042667 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表