ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 怎样通过这么奇葩的两列数据找到第三列中唯一对应的数据?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2019-11-6 00:32 | 显示全部楼层 |阅读模式
本帖最后由 gcloveu 于 2019-11-6 00:43 编辑

有A表和B表两个工作表,通过货号和订货数量,找到A表中对应的批次,奇葩在货号和订货数量存在同时相同的情况,但他们的批次不同。要求在B表中返回不同的批次!
难点一:通过货号和订货数量两个条件找到对应的批次
难点二:货号和订货数量都相同的对应不同的批次(即假如有两个货号和订货数量都相同的数据分别对应批次3和批次9,那么在B表中就是一个数据返回3,一个数据返回9)

注:为了方便验证,正确的对应结果是从1至72递增的数字

对应数据.7z (16.47 KB, 下载次数: 8)

TA的精华主题

TA的得分主题

发表于 2019-11-6 05:14 | 显示全部楼层
倒着追,现在批号列循环,看哪个值等于货号和订货量,然后分别填入批号

TA的精华主题

TA的得分主题

发表于 2019-11-6 07:43 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
简单的问题没什么难度

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-11-6 08:34 | 显示全部楼层
renkangjizhen 发表于 2019-11-6 05:14
倒着追,现在批号列循环,看哪个值等于货号和订货量,然后分别填入批号

我就是倒着用批号列循环的啊,但是结果不对,求解!

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-11-6 08:36 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
larer 发表于 2019-11-6 07:43
简单的问题没什么难度

大神一出手,就知有没有!拜求代码,多谢!

TA的精华主题

TA的得分主题

发表于 2019-11-6 09:14 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
批次的代码:
2019-11-6批次.png

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-11-6 09:59 | 显示全部楼层

多谢蓝版的回复!没想到这么多年蓝版还一直在坚持不懈的为我们答疑解惑,诲人不倦!佩服!佩服!感谢这么多年一直有您与我们相伴~
言归正传!
第一个问题完美解决,但是第二个问题的结果不对。两个相同的数据结果返回的都是72,我的目的是一个返回35,一个返回72源数据
源数据.png
结果
对应数据.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2019-11-6 14:40 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
  1. Private Sub CommandButton1_Click()
  2. Dim d, Arr, i&, Myr&, Brr
  3. Set d = CreateObject("Scripting.Dictionary")
  4. Sheet1.Activate
  5. Myr = Sheet2.Cells(Sheet2.Rows.Count, 5).End(xlUp).Row
  6. Arr = Sheet2.Range("a8:p" & Myr)
  7. For i = 1 To UBound(Arr)
  8.     d(Arr(i, 5) & "|" & Arr(i, 10)) = Arr(i, 16)
  9. Next
  10. Myr = Cells(Rows.Count, 2).End(xlUp).Row
  11. Brr = Range("a18:k" & Myr)
  12. For i = 1 To UBound(Brr)
  13.     If d.Exists(Brr(i, 2) & "|" & Brr(i, 6)) Then
  14.         Cells(i + 17, 11) = d(Brr(i, 2) & "|" & Brr(i, 6))
  15.     End If
  16. Next
  17. End Sub
复制代码
大家帮我看看蓝版的这个代码要怎样改才能符合第二个问题的要求?
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

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

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

GMT+8, 2024-4-25 13:39 , Processed in 0.038343 second(s), 16 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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