ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: lyr

[求助] 对于某些函数计算

[复制链接]

TA的精华主题

TA的得分主题

发表于 2007-8-27 12:41 | 显示全部楼层
多谢楼主        

TA的精华主题

TA的得分主题

发表于 2007-9-24 17:31 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

首先对CHENJUN的创意表示肯定,但...

    呵呵,我觉得毕竟你的公式有个很大的瑕疵(当然瑕不掩瑜),那就是用了两个SUMIF,我觉得应该可以控制INDEXX(SHT_NAME,ROW(1:5))对表进行控制。

={SUM(SUMIF(INDIRECT(INDEX(sht_name,COLUMN(A:E))&"!A1:F1"),IF(ROW(1:5),"李","李"),INDIRECT(INDEX(sht_name,COLUMN(A:E))&"!A2:F2")))}

tsK9LqwA.rar (4.3 KB, 下载次数: 73)
[此贴子已经被作者于2007-9-24 17:35:45编辑过]

TA的精华主题

TA的得分主题

发表于 2007-9-24 18:03 | 显示全部楼层

丢人呀,发现我上边的公式还是不对的,呵呵、

我正在改

TA的精华主题

TA的得分主题

发表于 2007-9-24 18:09 | 显示全部楼层
chenjun老大真厉害呀!我在2005年才开始学习Excel,到现在遇到这种问题也不轻松啊!而老大2003年就会了,真是羡慕!

TA的精华主题

TA的得分主题

发表于 2007-9-24 19:28 | 显示全部楼层

呵呵,楼上的斑竹你应该明白我为什么要问那么EASY的问题了吧,呵呵,当时就是被INDEX(SHT_NAME,ROW(1:5))给搞死了.

以为应该是对的,但实际上不对,隐隐约约中记得在一个讲述什么引用函数的时候 以为老大提到过 什么 index()函数的缺陷是只能提取1行,一列,不能多行。我想现在可以补充的时候INDEX()不能通过上面的方式来攫取一部分作为新的内存数组。

={SUM(SUMIF(INDIRECT(LOOKUP(ROW(1:5),ROW(1:6),sht_name)&"!A1:F1"),IF(ROW(1:5),"李","李"),INDIRECT(LOOKUP(ROW(1:5),ROW(1:6),sht_name)&"!A2:F2")))}

附件:

DSoIrBWg.rar (4.31 KB, 下载次数: 116)
[此贴子已经被作者于2007-9-24 19:29:09编辑过]

TA的精华主题

TA的得分主题

发表于 2008-8-21 14:43 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助

弱弱的问一个弱智问题:

在用这个公式的时候,看到的公式是这样的

{=SUM(SUMIF(INDIRECT(IF(sht_name=csht_name,INDEX(sht_name,1),sht_name)&"!A1:F1"),"李",INDIRECT(IF(sht_name=csht_name,INDEX(sht_name,1),sht_name)&"!A2:F2")))-SUMIF(INDIRECT(INDEX(sht_name,1)&"!A1:F1"),"李",INDIRECT(INDEX(sht_name,1)&"!A2:F2"))}

即前后都有“{}”,但是点进去复制公式的时候,这两个“{}”就不见了,并且返回的值也变成了0。手动添加“{}”,发现显示公式出错。

这是为什么呢??

TA的精华主题

TA的得分主题

发表于 2008-8-21 15:30 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2008-8-22 11:26 | 显示全部楼层

追加提问一下,以上这个公式只求了“李”的工资。

我在实际应用的时候,取20张表,并且取几十个人的1-12月每个月的工资,这样做法,这个公式也可以完成。

但是结果是excel运行速度非常慢。每更改任何一个单元格,都需要等待很久。请问有没有什么办法简化公式或者提高运行速度呢?

TA的精华主题

TA的得分主题

发表于 2003-11-13 09:58 | 显示全部楼层
以下是引用在水一方在2003-11-12 17:49:00的发言: 再请问Chenjun大侠,如果姓名有很多,公式中的姓名也要一个一个改吗?
公式中的姓名改为对姓名单元格的引用。

TA的精华主题

TA的得分主题

发表于 2003-11-11 21:01 | 显示全部楼层
以下是引用在水一方在2003-11-11 20:50:00的发言: 请问Chenjun大侠,因为我不懂三维数组,所以请问如果A列是姓名,B列是工资,公式应该怎么修改?
{=SUM(SUMIF(INDIRECT(IF(sht_name=csht_name,INDEX(sht_name,1),sht_name)&"!A:A"),"李",INDIRECT(IF(sht_name=csht_name,INDEX(sht_name,1),sht_name)&"!B:B")))-SUMIF(INDIRECT(INDEX(sht_name,1)&"!A:A"),"李",INDIRECT(INDEX(sht_name,1)&"!B:B"))}
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-6-25 15:06 , Processed in 0.042044 second(s), 7 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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