ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[已解决] 想好好久没结果 ,希望大神帮忙

[复制链接]

TA的精华主题

TA的得分主题

发表于 2019-1-12 14:22 | 显示全部楼层 |阅读模式

关于条件查询 汇总的问题 ,比较笨 ,想了好久
希望大神帮忙
非常感谢
Excel 求助.7z (9.74 KB, 下载次数: 15)

TA的精华主题

TA的得分主题

发表于 2019-1-12 14:41 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
数组公式
=SUM(MMULT(N(IF(DATA!B$2:B$20=B2,DATA!A$2:A$20)=TRANSPOSE(Input!B$2:B$4)),Input!C$2:C$4)*DATA!C$2:C$20)

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2019-1-12 14:43 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 wofuocibei2008 于 2019-1-12 14:44 编辑

SUM((TRANSPOSE(B2&Input!$B$2:$B$4)=DATA!$B$2:$B$20&DATA!$A$2:$A$20)*TRANSPOSE(Input!$C$2:$C$4)*DATA!$C$2:$C$20)数组

TA的精华主题

TA的得分主题

发表于 2019-1-12 14:43 | 显示全部楼层
SELECT 分类,sum(规格*数量) FROM DATA INNER JOIN [Input] ON DATA.名称 = Input.名称 group by 分类

TA的精华主题

TA的得分主题

发表于 2019-1-12 17:46 | 显示全部楼层
提供一个PowerQuery的解法供参考,数据源扩展,刷新结果就可以更新。
有兴趣可以试试以下M语句:
  1. let
  2.     DATA = Excel.CurrentWorkbook(){[Name="DATA"]}[Content],
  3.     Input = {{0,"龥",0}}&Table.ToRows(Excel.CurrentWorkbook(){[Name="Input"]}[Content]),
  4.     Output = Excel.CurrentWorkbook(){[Name="Output"]}[Content],
  5.     Result = Table.AddColumn( Output,"结果",each List.Accumulate( Table.ToRows(Table.SelectRows(DATA,(z)=>z[分类]=[分类])),
  6.                                                                 0,
  7.                                                                (s,c)=>s+( let p=List.PositionOf(Input,c,0,(x,y)=>x{1}=y{0})
  8.                                                                           in Input{p+Byte.From(p=-1)}{2})*c{2} ) )
  9. in
  10.     Result
复制代码
截图如下:
2019-01-12_174500.jpg
一并附上文件:
Excel 求助.xlsx.zip (18.92 KB, 下载次数: 1)

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-1-12 20:02 | 显示全部楼层
江苏永能朱兴华 发表于 2019-1-12 14:41
数组公式
=SUM(MMULT(N(IF(DATA!B$2:B$20=B2,DATA!A$2:A$20)=TRANSPOSE(Input!B$2:B$4)),Input!C$2:C$4)*D ...

谢谢您!解决了问题,很感激

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-1-12 20:03 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
wofuocibei2008 发表于 2019-1-12 14:43
SUM((TRANSPOSE(B2&Input!$B$2:$B$4)=DATA!$B$2:$B$20&DATA!$A$2:$A$20)*TRANSPOSE(Input!$C$2:$C$4)*DATA! ...

谢谢,这个公式我想一年也想不出来 ,非常感激

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-1-12 20:05 | 显示全部楼层
飞天篮球猪 发表于 2019-1-12 17:46
提供一个PowerQuery的解法供参考,数据源扩展,刷新结果就可以更新。
有兴趣可以试试以下M语句:
截图如 ...

非常感谢 ,论坛里大牛啊,谢谢

TA的精华主题

TA的得分主题

发表于 2019-1-12 20:16 | 显示全部楼层
本帖最后由 丢丢表格 于 2019-1-12 20:18 编辑
江苏永能朱兴华 发表于 2019-1-12 14:41
数组公式
=SUM(MMULT(N(IF(DATA!B$2:B$20=B2,DATA!A$2:A$20)=TRANSPOSE(Input!B$2:B$4)),Input!C$2:C$4)*D ...

可以用 SUMIF  的
=SUMPRODUCT(Input!C$2:C$4*SUMIFS(DATA!C:C,DATA!B:B,B2,DATA!A:A,{"A";"C";"D"}))
也写成
=SUMPRODUCT(Input!C$2:C$4*SUMIFS(DATA!C:C,DATA!B:B,B2,DATA!A:A,Input!B$2:B$4))

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2019-1-12 20:19 来自手机 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
谢老大指点
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

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

GMT+8, 2024-4-25 02:46 , Processed in 0.047949 second(s), 13 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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