Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 11408|回复: 23

[已解决]一个零钱计算器,不知道有没有办法实现

[复制链接]
发表于 2014-9-10 01:55 | 显示全部楼层 |阅读模式
10学分
发工资的时候,经常发现零钱不好找,要不是员工没有零钱找,就是发的时候没有零钱付。

现在有一个表格,sheet2是员工姓名和应发工资金额,sheet1有一个多选择列表窗体,如何把员工姓名全部放到列表里面多选,然后点击开始计算,把选中的员工需要发的工资100元需要多少钱,50的需要多少钱,20、10、5、1元的需要多少钱填入sheet1的B15、B16、AB7、B18、B19里面。

这个不知道能不能实现,附件如下,谢谢各位大神了。
最佳答案
2014-9-10 08:54
本帖最后由 zjdh 于 2014-9-10 14:45 编辑

我来给个窗体的。(借用3楼思路)
零钱计算器2.rar (21.6 KB, 下载次数: 94)

零钱计算器1.rar

13.21 KB, 下载次数: 26

最佳答案

发表于 2014-9-10 01:55 | 显示全部楼层
零钱计算器3.rar (21.29 KB, 下载次数: 24)

评分

参与人数 1 +1 收起 理由
ww87398804 + 1 赞一个!

查看全部评分

回复

使用道具 举报

发表于 2014-9-10 03:33 | 显示全部楼层
  1. Sub Macro1()
  2. Dim arr, brr, crr, d, i&
  3. Set d = CreateObject("scripting.dictionary")
  4. arr = Range("a1").CurrentRegion
  5. ReDim brr(1 To UBound(arr) - 1, 1 To 1)
  6. crr = Range("e2").CurrentRegion
  7. For i = 2 To UBound(arr)
  8.     s100 = arr(i, 2) \ 100
  9.     d(100) = d(100) + s100
  10.     If s100 <> 0 Then brr(i - 1, 1) = s100 & "×100+"
  11.     s50 = (arr(i, 2) - s100 * 100) \ 50
  12.     d(50) = d(50) + s50
  13.     If s50 <> 0 Then brr(i - 1, 1) = brr(i - 1, 1) & s50 & "×50+"
  14.     s20 = (arr(i, 2) - s100 * 100 - s50 * 50) \ 20
  15.     d(20) = d(20) + s20
  16.     If s20 <> 0 Then brr(i - 1, 1) = brr(i - 1, 1) & s20 & "×20+"
  17.     s10 = (arr(i, 2) - s100 * 100 - s50 * 50 - s20 * 20) \ 10
  18.     d(10) = d(10) + s10
  19.     If s10 <> 0 Then brr(i - 1, 1) = brr(i - 1, 1) & s10 & "×10+"
  20.     s5 = (arr(i, 2) - s100 * 100 - s50 * 50 - s20 * 20 - s10 * 10) \ 5
  21.     d(5) = d(5) + s5
  22.     If s5 <> 0 Then brr(i - 1, 1) = brr(i - 1, 1) & s5 & "×5+"
  23.     s1 = arr(i, 2) Mod 5
  24.     d(1) = d(1) + s1
  25.     If s1 <> 0 Then brr(i - 1, 1) = brr(i - 1, 1) & s1 & "×1"
  26. Next
  27. For i = 1 To UBound(crr)
  28.     crr(i, 1) = d(crr(i, 1))
  29. Next
  30. Range("c2").Resize(UBound(brr)) = brr
  31. Range("f2").Resize(UBound(crr)) = crr
  32. End Sub
复制代码
回复

使用道具 举报

发表于 2014-9-10 03:43 | 显示全部楼层
………………

零钱计算器.zip

16.94 KB, 下载次数: 29

评分

参与人数 1 +1 收起 理由
ww87398804 + 1 赞一个!

查看全部评分

回复

使用道具 举报

发表于 2014-9-10 08:54 | 显示全部楼层    本楼为最佳答案   
本帖最后由 zjdh 于 2014-9-10 14:45 编辑

我来给个窗体的。(借用3楼思路)
零钱计算器2.rar (21.6 KB, 下载次数: 94)

零钱计算器2.rar

21.6 KB, 下载次数: 1

评分

参与人数 1 +1 收起 理由
ww87398804 + 1 赞一个!

查看全部评分

回复

使用道具 举报

发表于 2014-9-10 09:24 | 显示全部楼层
4楼附件又作了点修改。

评分

参与人数 1 +1 收起 理由
ww87398804 + 1 赞一个!

查看全部评分

回复

使用道具 举报

 楼主| 发表于 2014-9-10 09:25 | 显示全部楼层
zjdh 发表于 2014-9-10 08:54
我来给个窗体的。(借用3楼思路)

谢谢了,可以用的。
回复

使用道具 举报

 楼主| 发表于 2014-9-10 09:25 | 显示全部楼层
dsmch 发表于 2014-9-10 03:43
………………

谢谢你。
回复

使用道具 举报

发表于 2014-9-10 09:27 | 显示全部楼层
算零钱是挺麻烦的
回复

使用道具 举报

 楼主| 发表于 2014-9-10 10:24 | 显示全部楼层
zjdh 发表于 2014-9-10 08:54
我来给个窗体的。(借用3楼思路)

可以再加一个合计的控件在窗体里面吗?这样才好合计合计本次这几个员工发了多少钱。谢谢了哦!
回复

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-27 06:43 , Processed in 0.285634 second(s), 20 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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