EXCEL如何运用宏多条件查询
我有一个数据报表,表1:A列为货品单号,B列为单价,F列为发票号码;表2:A列为货品单号,B列为单价,C列为发票号码,现我要把表1:F列的发票号码填充到表2:C列的发票号...
我有一个数据报表,表1:A列为货品单号,B列为单价,F列为发票号码;表2:A列为货品单号,B列为单价,C列为发票号码,现我要把表1:F列的发票号码填充到表2:C列的发票号码那栏去,前提条件是表1和表2的货品单号和单价同时相同(也就是表1A列跟B列和表2A列跟B列同时相同的情况下),如何运用宏编码实现上述功能呢?只要一个按钮,表1F列在单号和单价相同的情况下填充到表2C列发票号码那栏去
展开
8个回答
展开全部
这是一个用ACCESS解决非常容易的问题可是你却要用excel做。用VLOOKP()函数可以解决。没必要编宏的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
1开启宏录制,
2实际操作多条件查询,
3再查看宏代码,
4修改代码。(主要是精简代码,修改指定单元格语句为通用性地址单元)
2实际操作多条件查询,
3再查看宏代码,
4修改代码。(主要是精简代码,修改指定单元格语句为通用性地址单元)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不用宏啊 ,用公式就可以解决用vlookup的公式
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
方法1 公式
在表2 C1单元格输入下面的公式向下拖拽填充
=VLOOKUP(A1&B1,IF({1,0},Sheet1!$A$1:$A$20&Sheet1!$B$1:$B$20,Sheet1!$F$1:$F$20),2,0)
方法2 VBA宏
使用下面的VBA代码
添加一个模块,粘贴下面的代码,回到工作表 ALT+F8 选择这个宏名执行.
或者绑定这个宏到一个窗体按钮,执行
Sub 取发票号()
Dim SJarr()
Dim SJObj As Object
With Sheet1
sjendrow = .Range("A65536").End(xlUp).Row
SJarr = .Range("A1:G" & sjendrow).Value
End With
Set SJObj = CreateObject("scripting.dictionary")
For sjh = 1 To UBound(SJarr)
SJObj(SJarr(sjh, 1) & SJarr(sjh, 2)) = SJarr(sjh, 6)
Next
endrow = Sheet2.Range("B65536").End(xlUp).Row
For i = 1 To endrow
With Sheet2
CXNR = .Range("A" & i) & .Range("B" & i)
If SJObj.Exists(CXNR) Then
.Range("C" & i) = SJObj.Item(CXNR)
End If
End With
Next
End Sub
在表2 C1单元格输入下面的公式向下拖拽填充
=VLOOKUP(A1&B1,IF({1,0},Sheet1!$A$1:$A$20&Sheet1!$B$1:$B$20,Sheet1!$F$1:$F$20),2,0)
方法2 VBA宏
使用下面的VBA代码
添加一个模块,粘贴下面的代码,回到工作表 ALT+F8 选择这个宏名执行.
或者绑定这个宏到一个窗体按钮,执行
Sub 取发票号()
Dim SJarr()
Dim SJObj As Object
With Sheet1
sjendrow = .Range("A65536").End(xlUp).Row
SJarr = .Range("A1:G" & sjendrow).Value
End With
Set SJObj = CreateObject("scripting.dictionary")
For sjh = 1 To UBound(SJarr)
SJObj(SJarr(sjh, 1) & SJarr(sjh, 2)) = SJarr(sjh, 6)
Next
endrow = Sheet2.Range("B65536").End(xlUp).Row
For i = 1 To endrow
With Sheet2
CXNR = .Range("A" & i) & .Range("B" & i)
If SJObj.Exists(CXNR) Then
.Range("C" & i) = SJObj.Item(CXNR)
End If
End With
Next
End Sub
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询