ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 按出货的数量找未清订单明细

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-2-17 14:08 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 wqhsz385919 于 2024-2-17 14:09 编辑

配单.7z (27.32 KB, 下载次数: 6)
你好!请帮忙看下,按出货的数量找未清订单明细里凑单,按订单的先后顺序,自己学着写,中间逻辑实在想不到,请大侠帮忙指导,谢谢!
举例:采购工厂&料号 出货1000,就在未清订单明细里找到这个采购工厂&料号,数量刚好1000,附件有手工模拟的结果
以上谢谢!
以下是自己学着写的代码:
Sub peidan()
Dim brr(1 To 1000, 1 To 14)
Set d = CreateObject("scripting.dictionary")
With Sheets("未清订单")
     cr = .Range("a1").CurrentRegion
End With
With Sheets("明天出货")
     ar = .Range("a1").CurrentRegion
     For i = 2 To UBound(ar)
         s = ar(i, 2) & "@" & ar(i, 6)
         d(s) = d(s) + ar(i, 9)
     Next
End With
k0 = d.keys

For Each kk In k0
    For i = 2 To UBound(cr)
        s = cr(i, 9) & "@" & cr(i, 5)
        If d.exists(s) Then
           If cr(i, 7) - d(kk) < 0 Then
              k = k + 1: ss = ss + cr(i, 7)
                If ss < d(kk) Then
                For j = 1 To 14
                  brr(k, j) = cr(i, j)
                Next
               End If
                brr(k, 7) = cr(i, 7)
              Else
               k = k + 1
               For j = 1 To 14
                  brr(k, j) = cr(i, j)
               Next
               brr(k, 7) = d(kk)
               Exit For
              End If
          End If
     Next
  Next

With Sheets("出货配单")
      .UsedRange.Offset(1).Clear
     .AutoFilterMode = False
     .Columns(3).NumberFormatLocal = "@"
     With .Range("a2").Resize(k, 14)
          .Value = brr
          .Borders.LineStyle = 1
          .HorizontalAlignment = xlCenter
          .VerticalAlignment = xlCenter
          .Font.Name = "等线"
          .Font.Size = 9
     End With
End With
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-17 19:46 | 显示全部楼层
新年好!请大侠帮忙指导,多谢!

TA的精华主题

TA的得分主题

发表于 2024-2-17 20:37 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 shiruiqiang 于 2024-2-17 20:39 编辑

判断字典的值的3种情况

image.jpg

配单.rar

25.12 KB, 下载次数: 14

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-17 21:21 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-18 13:02 | 显示全部楼层
shiruiqiang 发表于 2024-2-17 20:37
判断字典的值的3种情况

HI 您好!
    我想增加2条预警,加了个循环,结果不对,就是似乎不能放到FOR X循环内,但放在外面,却又想不到,烦请帮忙再看下,多谢!

cr = Sheets("未清订单").Range("a1").CurrentRegion
For x = 2 To UBound(cr)
  s = cr(x, 9) & "|" & cr(x, 5)
   dcou(s) = dcou(s) + cr(i, 7)
       For Each kk In d.keys
           If Not dcou.exists(kk) Then MsgBox kk & "无未清PO,请核实!"
           If dcou(kk) < d(kk) Then MsgBox kk & "未清PO,请核实!"
       Next

    If d.exists(s) Then
   
     If d(s) = 0 Then
   
     d.Remove s
     Else
        If d(s) >= cr(x, 7) Then
         k = k + 1
           For y = 1 To UBound(cr, 2)
           brr(k, y) = cr(x, y)
           Next
           d(s) = d(s) - cr(x, 7)
         Else
          k = k + 1
           For y = 1 To UBound(cr, 2)
           brr(k, y) = cr(x, y)
           Next
           brr(k, 7) = d(s)
           d(s) = 0
         End If
     End If
    End If
Next

TA的精华主题

TA的得分主题

发表于 2024-2-18 20:49 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-19 08:14 | 显示全部楼层
您好,
想提醒:
1.出货的编码是否存在未清订单,如果没有,就提醒使用者没有未清订单要排查
2..出货的编码确实也存在未清订单,但未清订单数量不够,就提醒使用者排查异常

TA的精华主题

TA的得分主题

发表于 2024-2-19 09:19 | 显示全部楼层
不知道你要表达啥,盲猜一个吧

配单.rar

26.21 KB, 下载次数: 14

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-19 12:09 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
感谢大侠关注,您的理解非常对,我就是这么想的
不过,我还是搞错逻辑了,是反着过来了,正常应该是:
是出货到未清订单中去找,未清订单没有,就反馈没有,这是一种  ,另一种 就是短缺,如总出货数量为1000,未清订单合计只有990,则要提示短缺10,另外990正常配单出来
审核好慢,只好这样回复了
实在不好意思,给大侠发个红包,谢谢!
image.png

TA的精华主题

TA的得分主题

发表于 2024-2-19 14:51 | 显示全部楼层
"如总出货数量为1000,未清订单合计只有990"?
个人理解,“未清订单”应该是需求量,“出货”是能满足的量,“出货”<“未清订单”提示吧?
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-18 19:32 , Processed in 0.046654 second(s), 16 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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