2017-01-03 125 views
0

enter image description hereenter image description here我試圖得到多個VLOOKUP在單細胞多VLOOKUP結果

我得到#VALUE!錯誤與下面的功能,需要幫助糾正代碼

MultipleLookupNoRept(Lookupvalue As String, LookupRange As Range, ColumnNumber As Integer) 
Dim i As Long 
Dim Result As String 
For i = 1 To LookupRange.Columns(1).Cells.Count 
    If LookupRange.Cells(i, 1) = Lookupvalue Then 
    For J = 1 To i - 1 
    If LookupRange.Cells(J, 1) = Lookupvalue Then 
     If LookupRange.Cells(J, ColumnNumber) = LookupRange.Cells(i, ColumnNumber) Then 
     GoTo Skip 
     End If 
    End If 
    Next J 
    Result = Result & " " & LookupRange.Cells(i, ColumnNumber) & "," 
Skip: 
    End If 
Next i 
MultipleLookupNoRept = Left(Result, Len(Result) - 1) 
End Function 
+0

你的代碼是偉大的,你忘了一個小東西,從你的'Function'返回'String'。將第一行修改爲'Function MultipleLookupNoRept(Lookupvalue As String,LookupRange As Range,ColumnNumber As Integer)As String',它可以爲你工作 –

+0

謝謝但是我再次遇到同樣的錯誤 –

+0

你怎麼使用它?您是從Excel工作表中輸入正確的參數? –

回答

0

此代碼對我的作品。大部分是原始代碼。

Function MultipleLookupNoRept(Lookupvalue As String, LookupRange As Range, ColumnNumber As Integer) As String 
    Dim i As Long 
    Dim Result As String 

    For i = 1 To LookupRange.Columns(1).Cells.Count 
     If LookupRange.Cells(i, 1) = Lookupvalue Then 
     Result = Result & " " & LookupRange.Cells(i, ColumnNumber) & "," 
     End If 
    Next i 
    If (Len(Result) = 0) Then 
     MultipleLookupNoRept = 0 
     Else 
     MultipleLookupNoRept = Left(Result, Len(Result) - 1) 
    End If 

End Function 
+0

感謝工作正常。 –

+0

嗨需要對此代碼進行一次更改。如果結果在複製其考慮只有一個(見我附上的截圖) –

+0

修訂後的代碼。請嘗試 – nightcrawler23

0
'This code should help 
' Syntax =MVLOOKUP(Lookup_value,Table_array,Col_index_number) 
Option Explicit 
Function mvlookup(lookupValue, tableArray As Range, colIndexNum As Long, _ 
Optional NotUsed As Variant) As Variant 

Dim initTable As Range 
Dim myRowMatch As Variant 
Dim myRes() As Variant 
Dim myStr As String 
Dim initTableCols As Long 
Dim i As Long 
Dim ubound_myRes As Long 

Set initTable = Nothing 
On Error Resume Next 
Set initTable = Intersect(tableArray, _ 
tableArray.Parent.UsedRange.EntireRow) 
On Error GoTo 0 

If initTable Is Nothing Then 
mvlookup = CVErr(xlErrRef) 
Exit Function 
End If 

initTableCols = initTable.Columns.Count 

i = 0 
Do 
myRowMatch = Application.Match(lookupValue, initTable.Columns(1), 0) 

If IsError(myRowMatch) Then 
Exit Do 
Else 
i = i + 1 
ReDim Preserve myRes(1 To i) 
myRes(i) _ 
= initTable(1).Offset(myRowMatch - 1, colIndexNum - 1).Text 
If initTable.Rows.Count <= myRowMatch Then 
Exit Do 
End If 
On Error Resume Next 
Set initTable = initTable.Offset(myRowMatch, 0) _ 
.Resize(initTable.Rows.Count - myRowMatch, _ 
initTableCols) 
On Error GoTo 0 
If initTable Is Nothing Then 
Exit Do 
End If 
End If 
Loop 

If i = 0 Then 
mvlookup = CVErr(xlErrNA) 
Exit Function 
End If 

myStr = "" 
For i = LBound(myRes) To UBound(myRes) 
myStr = myStr & ", " & myRes(i) 
Next i 

mvlookup = Mid(myStr, 3) 

End Function