Я думаю, что это похоже на похожий вопрос, на который я только что ответил с VBA. Для вашего решения вы должны скопировать столбец Key
, удалить дубликаты, а затем использовать формулу для вызова UDF, который возвращает строку значений, разделенных запятыми.
Вот окончательный результат этого вопроса:
И вот код:
Option Explicit
Function LookupCSVResults(lookupValue As Variant, lookupRange As Range, resultsRange As Range) As String
Dim s As String 'Results placeholder
Dim sTmp As String 'Cell value placeholder
Dim r As Long 'Row
Dim c As Long 'Column
Const strDelimiter = "|||" 'Makes InStr more robust
s = strDelimiter
For r = 1 To lookupRange.Rows.Count
For c = 1 To lookupRange.Columns.Count
If lookupRange.Cells(r, c).Value = lookupValue Then
'I know it's weird to use offset but it works even if the two ranges
'are of different sizes and it's the same way that SUMIF works
sTmp = resultsRange.Offset(r - 1, c - 1).Cells(1, 1).Value
If InStr(1, s, strDelimiter & sTmp & strDelimiter) = 0 Then
s = s & sTmp & strDelimiter
End If
End If
Next
Next
'Now make it look like CSV
s = Replace(s, strDelimiter, ",")
If Left(s, 1) = "," Then s = Mid(s, 2)
If Right(s, 1) = "," Then s = Left(s, Len(s) - 1)
LookupCSVResults = s 'Return the function
End Function
Чтобы показать пример, вот формула, показанная в ячейке E1
:
=LookupCSVResults(D1,B1:B7,A1:A7)
А вот CSV-версия данных в диапазоне A1:D7
:
Адам, красный ,, Красный
Адам, зеленый ,, зеленый
Адам, голубой ,, синий
Боб, красный ,, желтый
Боб, желтый ,,
Боб, зеленый ,,
Карл, красный ,,