【问题标题】:How to match values using excel Marcos in different workbooks?如何在不同的工作簿中使用 excel 宏匹配值?
【发布时间】:2021-06-22 12:44:08
【问题描述】:

所以我有两个工作簿。一个是 ADUsers.xls,另一个是 DeviceInventory.xls

ADUsers.xls - 它有不同的列,其中一列是用户 ID(e2 到 e565),最后一列是找到的匹配项(g2 到 g565)。

DeviceInventory.xls - 它有不同的列,但我们需要的是 userID (a3 - a3199)。

问题 - 我们需要做的是一一检查 ADUsers excel 表中的 userID,并对照 DeviceInventory excel 表中的 userID 列进行检查。如果在任何 3199 行中的某处找到匹配项,我想在 G 列的 ADUsers.xls 的相应行中插入“MATCH FOUND”。

知道如何使用 excel 宏来实现这一点吗?对此提出建议将不胜感激。

【问题讨论】:

  • 你不需要宏...=IF(ISNUMBER(MATCH(....),"MATCH FOUND","").
  • 哪个工作簿将包含代码?
  • @VBasic2008 ADUSers.xls 将包含代码
  • @BigBen 这是两个不同的工作簿。我还能用这个吗?对不起,我对这一切都不熟悉
  • 当然,您可以在一个工作簿中使用一个公式来引用另一个工作簿中的单元格。

标签: excel vba macos excel-formula


【解决方案1】:

查找匹配项

Option Explicit

Sub matchUsers()
    
    ' Adjust the following constants
    Const sFilePath As String = "C:\Test\DeviceInventory.xls"
    Const sName As String = "Sheet1"
    Const dName As String = "Sheet1"
    
    Dim srg As Range
    Set srg = Workbooks.Open(FilePath).Worksheets(sName).Range("A3:A3199")
    
    Dim drg As Range: Set drg = ThisWorkbook.Worksheets(dName).Range("E2:E565")
        
    Dim dCell As Range
    For Each dCell In drg.Cells
        If IsNumeric(Application.Match(dCell.Value, srg, 0)) Then
            dCell.Offset(, 2).Value = "MATCH FOUND"
        End If
    Next dCell
    
End Sub

【讨论】:

  • 好的。所以它说 - 下标超出范围。知道它是关于什么的吗?实际上我在 A 列中应用了一些过滤器,因此这些值不是连续的..比如 A3 然后 A4 然后 A8 然后 A19 ..你认为这是导致这个问题的原因吗?
  • 我不这么认为。哪一行抛出错误?您是否调整了工作表名称和源工作簿路径?工作表选项卡名称可能不是 Sheet1,并且工作簿可能不在文件夹 C:\Test 中。
  • 设置 srg = Workbooks.Open(sFilePath).Worksheets(sName).Range("A3:A3199") - 这一行
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-08-01
  • 1970-01-01
  • 1970-01-01
  • 2020-06-23
  • 2023-01-12
相关资源
最近更新 更多