Hur returnerar jag flera uppslagsvärden i en kommaseparerad cell?
I Excel kan vi använda VLOOKUP-funktionen för att returnera det första matchade värdet från en tabellceller, men ibland måste vi extrahera alla matchande värden och sedan separeras med en specifik avgränsare, som komma, bindestreck, etc ... i en enda cell som följande skärmdump visas. Hur kunde vi få och returnera flera uppslagsvärden i en kommaseparerad cell i Excel?
Returnera flera sökvärden i en kommaseparerad cell med användardefinierad funktion
Returnera flera sökvärden i en kommaseparerad cell med Kutools för Excel
Returnera flera sökvärden i en kommaseparerad cell med användardefinierad funktion
Normalt finns det inget direkt sätt för oss att extrahera och returnera flera matchande värden och åtskilda med komma i en cell, här kan du skapa en användardefinierad funktion för att lösa detta jobb, gör så här:
1. Håll ner ALT + F11 nycklar för att öppna Microsoft Visual Basic för applikationer fönster.
2. Klicka Insert > Modulernaoch klistra in följande kod i Modulerna Fönster.
VBA-kod: Returnera flera uppslagsvärden i en kommaseparerad cell
Function SingleCellExtract(LookupValue As String, LookupRange As Range, ColumnNumber As Integer, Char As String)
'Updateby Extendoffice
Dim I As Long
Dim xRet As String
For I = 1 To LookupRange.Columns(1).Cells.Count
If LookupRange.Cells(I, 1) = LookupValue Then
If xRet = "" Then
xRet = LookupRange.Cells(I, ColumnNumber) & Char
Else
xRet = xRet & "" & LookupRange.Cells(I, ColumnNumber) & Char
End If
End If
Next
SingleCellExtract = Left(xRet, Len(xRet) - 1)
End Function
3. Spara sedan den här koden och stäng modulfönstret, gå tillbaka till ditt kalkylblad och skriv in denna formel: = SingleCellExtract (D2, A2: B15,2, ",") i en tom cell som du vill returnera resultatet. Och tryck sedan på ange nyckel för att få resultatet, se skärmdump:
Anmärkningar: I ovanstående formel:
D2: anger cellvärdena som du vill slå upp;
A2: B15: är det dataområde som du vill hämta data;
2: siffran 2 är kolumnnumret som matchande värde ska returneras;
,: komma är avgränsaren som du vill separera flera värden.
Du kan ändra dem efter dina behov.
Returnera flera sökvärden i en kommaseparerad cell med Kutools för Excel
Om du har Kutools för Excelkommer den här uppgiften inte längre att vara ett problem. De Avancerade kombinera rader verktyget kan hjälpa dig att kombinera alla relativa värden baserat på en kolumn.
Kutools för Excel : med mer än 300 praktiska Excel-tillägg, gratis att prova utan begränsning på 30 dagar. |
När du har installerat Kutools för Excel, gör så här:
1. Välj det dataområde som du vill kombinera alla matchande värden baserat på en kolumn.
2. Klicka Kutools > Slå ihop och dela > Avancerade kombinera rader, se skärmdump:
3. I Kombinera rader baserat på kolumn Klicka på kolumnnamnet som du vill kombinera baserat på och klicka sedan på Primärnyckel knapp, se skärmdump:
4. Klicka sedan på ett annat kolumnnamn som du vill kombinera deras matchade värden och klicka på Kombinera för att välja en separator för att separera de kombinerade värdena, se skärmdump:
5. Klicka sedan OK knappen har alla motsvarande celler med samma värde kombinerats till en cell som är separerade med komma, se skärmdumpar:
Klicka för att få mer information om detta Advanced Combine Rows-verktyg ...
Ladda ner och testa gratis Kutools för Excel nu!
Demo: Returnera flera sökvärden i en kommaseparerad cell med Kutools för Excel
Bästa kontorsproduktivitetsverktyg
Uppgradera dina Excel-färdigheter med Kutools för Excel och upplev effektivitet som aldrig förr. Kutools för Excel erbjuder över 300 avancerade funktioner för att öka produktiviteten och spara tid. Klicka här för att få den funktion du behöver mest...
Fliken Office ger ett flikgränssnitt till Office och gör ditt arbete mycket enklare
- Aktivera flikredigering och läsning i Word, Excel, PowerPoint, Publisher, Access, Visio och Project.
- Öppna och skapa flera dokument i nya flikar i samma fönster, snarare än i nya fönster.
- Ökar din produktivitet med 50 % och minskar hundratals musklick för dig varje dag!