ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] BOM成本计算(有偿求助大神)

[复制链接]

TA的精华主题

TA的得分主题

发表于 2020-6-19 12:17 | 显示全部楼层
zhumw 发表于 2020-6-19 11:06
大神,您为我的问题付出了知识和时间,麻烦加我下,好兑现承诺,谢谢!

山版主的代码效率比我的高多了,我很多东西也都是跟他学的,大家共同学习交流,我就不那啥了

TA的精华主题

TA的得分主题

发表于 2020-6-19 15:46 | 显示全部楼层
学习,学习,点个赞

TA的精华主题

TA的得分主题

发表于 2020-6-20 11:47 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 飞天篮球猪 于 2020-6-22 09:06 编辑

提供一个Power Query 解法, 供参考...
20万行数据效率没有问题.....Revised
2020-06-22_090100.jpg

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-6-20 14:54 | 显示全部楼层
我看了这么多,都是某个层级的用量是将下级的全部数量进行相加,而原来写的那个数量被冲刷了,这个是对的吗?

TA的精华主题

TA的得分主题

发表于 2020-6-20 15:00 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
我的疑问一直是下面两个问题 1592636402(1).jpg

TA的精华主题

TA的得分主题

发表于 2020-6-20 15:23 | 显示全部楼层
本帖最后由 一把小刀闯天下 于 2020-6-20 15:25 编辑

'参与一下,,,

'总金额:70868.49 ,  总用量:14044.11

Option Explicit

Sub test()
  Dim arr, sum(99), i, j, p, cnt, total
  arr = [a1].CurrentRegion.Offset(1).Resize(, 5).Value
  ReDim brr(1 To UBound(arr, 1) - 1, 1 To 1)
  p = arr(UBound(arr, 1) - 1, 1)
  For i = UBound(arr, 1) - 1 To 2 Step -1
    If arr(i, 1) >= p Then
      brr(i, 1) = Round(arr(i, 3) * arr(i, 4), 2)
      cnt = cnt + arr(i, 3)
      total = total + brr(i, 1)
    Else
      brr(i, 1) = Round(arr(i, 3) * sum(p), 2)
      For j = arr(i, 1) + 1 To p
        sum(j) = 0
      Next
    End If
    sum(arr(i, 1)) = sum(arr(i, 1)) + brr(i, 1)
    p = arr(i, 1)
  Next
  brr(1, 1) = total: arr(1, 3) = cnt
  [e2].Resize(UBound(brr, 1)) = brr
  MsgBox "总金额:" & total & vbNewLine & "总用量:" & cnt
End Sub

评分

2

查看全部评分

TA的精华主题

TA的得分主题

发表于 2020-6-20 17:26 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-6-22 08:19 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-6-22 08:27 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
microyip 发表于 2020-6-20 15:00
我的疑问一直是下面两个问题

29行2的用处是说明做8行的1要2个,3行的1说明做2行的0要用1个;3行1的金额是所有对应下级2的金额之和,如果不为1,金额为下级单用量金额之和乘以用量

TA的精华主题

TA的得分主题

 楼主| 发表于 2020-6-22 08:30 | 显示全部楼层
aleaflin 发表于 2020-6-19 12:17
山版主的代码效率比我的高多了,我很多东西也都是跟他学的,大家共同学习交流,我就不那啥了

惭愧,我发此贴是真心有偿求助,尽管不多。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-9-27 20:05 , Processed in 0.047034 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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