将单元格中的值与命名范围匹配 - vba

时间:2018-01-14 03:26:14

标签: excel vba excel-vba named-ranges

我正在使用VBA来尝试查看来自一个工作簿的单元格中的值是否与另一个工作簿中的命名范围匹配,如果它们匹配,则从这些命名范围中的另一列复制粘贴值。我知道他们会匹配。目的只是将值复制到指定的命名范围内。

问题出在这一行:

If rng = ws2.Range("NamedRange") Then

以下是我的代码:

Sub Button4_Click()

Dim strFileName As String
Dim wb1 As Workbook
Dim ws1 As Worksheet
Dim wb2 As Workbook
Dim ws2 As Worksheet
Dim cell As Range
Dim rng As Range
Dim RangeName As String
Dim CellName As String


''Set wb2 = ActiveWorkbook
''Set ws2 = wb2.Sheet("Output")
''ws2.Range("D1:D12").Copy

''Set wb1 = ActiveWorkbook

strFileName = CreateObject("WScript.Shell").specialfolders("Desktop") & "\BAC GVP - Template_Update_121917.xlsm"

If Dir(strFileName) <> vbNullString Then
    Set wb1 = Workbooks.Open(strFileName)
Else
MsgBox "Sorry, the file does not exist on your Desktop at this time, please drop a copy to your Desktop from server!"
End If

''Set wb2 = ThisWorkbook
''Set ws2 = wb2.Sheets("Output")
''Set ws1 = wb1.Sheets("RVP Local GAAP")

''ws2.Range("D4:D12").Copy
''ws1.Range("G13:G21").PasteSpecial xlPasteValues

  ''RangeName = "myData"
  ''CellName = "G11:G83"

  ''Set cell = Worksheets("RVP Local GAAP").Range(CellName)
  ''ThisWorkbook.Names.Add Name:=RangeName, RefersTo:=cell

  ''RangeName = "NamedRange"
  ''CellName = "C4:C12"


Set wb2 = ThisWorkbook
Set ws2 = wb2.Sheets("Output")
Set ws1 = wb1.Sheets("RVP Local GAAP")

For Each rng In ws1.Range("CurrentTaxPerLocalGAAPProvision")
    If rng = ws2.Range("NamedRange") Then
    ws2.Range("ReportBalance").Copy
    ws1.Range("CurrentTaxPerLocalGAAPProvision").PasteSpecial xlPasteValues
    MsgBox "Values Copied Successfully"
End If
Next rng
MsgBox "Both Ranges do not have the same data"
End Sub

见下图 - 细胞G29被称为&#34; GVP_Donations_CurrentTaxPerLocalGAAPProvision&#34; ...因此,对于这个例子,我希望$ 4,313出现在细胞G29中

CurrentTaxPerLocalGAAPProvision:

CurrentTaxPerLocalGAAPProvision

范围(&#34; NameRange&#34;):

Range ("NameRange")

1 个答案:

答案 0 :(得分:0)

你的话说

If rng = ws2.Range("NamedRange") Then
由于尝试将rng的值(例如"" rng引用单元格G29时)与值数组(值中的值)进行比较,

崩溃了NamedRange“)。 VBA无法处理标量与向量的比较。但这并不是你想做的事情。

我相信,要做你想做的事情,你可以用以下代码替换你的循环:

'Loop through all the values in NamedRange
For Each rng In ws2.Range("NamedRange")
    'Transfer the value from the next column to the appropriate range in the
    'destination sheet
    ws1.Range(rng.Value).Value = rng.Offset(0, 1).Value
Next
MsgBox "Values Copied Successfully"

如果只复制“NamedRange”中某些的值,那么您可能需要进行一些测试以查看范围是否在正确的目标区域中:

Dim dstRng As Range
'Loop through all the values in NamedRange
For Each rng In ws2.Range("NamedRange")
    Set dstRng = Nothing
    On Error Resume Next
    Set dstRng = ws1.Range(rng.Value)
    On Error GoTo 0
    'Check that the range exists in destination sheet
    If Not dstRng Is Nothing Then
        'Check that the range exists in the appropriate area
        If Not Intersect(dstRng, ws1.Range("CurrentTaxPerLocalGAAPProvision")) Is Nothing Then
           'Transfer the value from the next column to the appropriate range in the
           'destination sheet
           dstRng.Value = rng.Offset(0, 1).Value
        End If
    End If
Next
MsgBox "Values Copied Successfully"