Note: The other languages of the website are Google-translated. Back to English
English English

Hoe celwaarden samen te voegen totdat een lege cel in een kolom wordt gevonden?

doc aaneenschakelen tot blanco 1

Ik heb bijvoorbeeld een lijst met waarden die enkele lege cellen bevat, en nu wil ik elke set gegevens tussen lege cellen samenvoegen tot een cel en de gecombineerde waarden in een andere kolom vermelden zoals in het volgende screenshot. Hoe kan ik cellen samenvoegen tot ik een lege cel in een kolom vind?

Voeg celwaarden samen totdat er een lege cel wordt gevonden in een kolom met VBA-code

Voeg celwaarden samen totdat een lege cel in een kolom wordt gevonden met Kutools voor Excel


pijl blauw rechts bel Voeg celwaarden samen totdat er een lege cel wordt gevonden in een kolom met VBA-code

Er is geen directe manier om een ​​reeks cellen tussen lege cellen samen te voegen, maar u kunt de volgende VBA-code toepassen om ermee om te gaan. Ga als volgt te werk:

1. Houd de ALT + F11 toetsen om de te openen Microsoft Visual Basic for Applications-venster.

2. Klikken Invoegen > Moduleen plak de volgende code in het Module Venster.

VBA-code: celwaarden samenvoegen totdat een lege cel wordt gevonden

Sub Concatenatecells()
'updateby Extendoffice
    Dim xRg As Range
    Dim xSaveToRg As Range
    Dim xTxt As String
    Dim xCell As Range
    Dim xTStr As String
    On Error Resume Next
    xTxt = ActiveWindow.RangeSelection.Address
    Set xRg = Application.InputBox("Please selecte the data range:", "Kutools for Excel", xTxt, , , , , 8)
    If xRg Is Nothing Then Exit Sub
    If xRg.Columns.Count > 1 Then
        MsgBox "the selected range is more than one column", vbInformation, "Kutools for Ecel"
        Exit Sub
    End If
    Set xSaveToRg = Application.InputBox("Please selecte output cell:", "Kutools for Excel", , , , , , 8)
    If xSaveToRg Is Nothing Then Exit Sub
    Set xSaveToRg = xSaveToRg.Cells(1)
    Application.ScreenUpdating = False
    For Each xCell In xRg
        If xCell <> "" Then
            xTStr = xTStr & xCell & " "
        Else
            xSaveToRg.Value = xTStr
            Set xSaveToRg = xSaveToRg.Offset(1)
            xTStr = ""
        End If
    Next
    If xTStr <> "" Then xSaveToRg.Value = Left(xTStr, Len(xTStr) - 1)
    Application.ScreenUpdating = True
End Sub

3. Druk vervolgens op F5 sleutel om deze code uit te voeren, en er verschijnt een promptvenster om u eraan te herinneren het gegevensbereik te selecteren dat u wilt aaneenschakelen, zie screenshot:

doc aaneenschakelen tot blanco 10

4. Dan klikken OK, en een ander promptvenster verschijnt, selecteer een cel om het aaneengeschakelde resultaat uit te voeren, zie screenshot:

doc aaneenschakelen tot blanco 11

5. En klik dan OK knop, en de kolomlijstgegevens worden aaneengeschakeld tussen de lege plekken, zie screenshot:

doc aaneenschakelen tot blanco 1


pijl blauw rechts bel Voeg celwaarden samen totdat een lege cel in een kolom wordt gevonden met Kutools voor Excel

Als je Kutools for Excel, een combinatie van zijn Transformeer bereik en Combineren functies, kunt u deze klus ook zo snel mogelijk afronden. De Transformeer bereik hulpprogramma kan u helpen bij het converteren van de enkele kolom naar een bereik, en de Combineren functie kan u helpen om het getransformeerde bereik samen te voegen tot een kolom.

Kutools for Excel : met meer dan 300 handige Excel-invoegtoepassingen, gratis te proberen zonder beperking in 30 dagen. 

Na het installeren van Kutools for Excelgaat u als volgt te werk:

1. Selecteer de cellen die u wilt samenvoegen en klik op Kutools > Bereik > Transformeer bereik, zie screenshot:

2. In de Transformeer bereik dialoogvenster, vink aan Enkele kolom om te bereiken optie onder de Type transformerenEn selecteer Een lege cel scheidt records onder de Rijen per record, zie screenshot:

doc aaneenschakelen tot blanco 3

3. Dan klikken Ok, en er verschijnt een promptvenster om u eraan te herinneren een cel te selecteren om het resultaat uit te voeren, zie screenshot:

doc aaneenschakelen tot blanco 4

4. Klikken OK, en de gegevens met één kolom zijn door de lege cel geconverteerd naar meerdere rijen en kolommen, zie screenshot:

doc aaneenschakelen tot blanco 5

5. De geconverteerde gegevens staan ​​in meerdere kolommen, dus u moet ze combineren in één kolom. Selecteer het gegevensbereik en klik op Kutools > Samenvoegen en splitsen > Combineer rijen, kolommen of cellen zonder gegevens te verliezen, zie screenshot:

6. In de Combineer kolommen of rijen dialoogvenster, doe de volgende opties:

(1.) Selecteer Combineer kolommen optie van de Om geselecteerde cellen te combineren volgens de volgende opties;

(2.) Geef vervolgens een scheidingsteken op waarvan u de aaneengeschakelde waarden wilt scheiden;

(3.) Selecteer hoe u met de gecombineerde cellen wilt omgaan. U kunt de originele gegevens behouden of verwijderen, en u kunt ook de gecombineerde cellen samenvoegen. Zie screenshot:

doc aaneenschakelen tot blanco 7

7. Klik na het voltooien van de instellingen op Ok or Toepassen knop, zijn de cellen samengevoegd tot één kolom met een specifiek scheidingsteken, zie screenshot:

doc aaneenschakelen tot blanco 8

Download en gratis proef Kutools voor Excel nu!


De beste tools voor kantoorproductiviteit

Kutools voor Excel lost de meeste van uw problemen op en verhoogt uw productiviteit met 80%

  • visfuik: Snel invoegen complexe formules, grafieken en alles wat je eerder hebt gebruikt; Versleutel cellen met wachtwoord; Maak een mailinglijst en stuur e-mails ...
  • Super Formula-balk (bewerk eenvoudig meerdere regels tekst en formule); Lay-out lezen (gemakkelijk grote aantallen cellen lezen en bewerken); Plakken in gefilterd bereik...
  • Voeg cellen / rijen / kolommen samen zonder gegevens te verliezen; Gespleten cellen inhoud; Combineer dubbele rijen / kolommen... Voorkom dubbele cellen; Vergelijk Ranges...
  • Selecteer Dupliceren of Uniek Rijen; Selecteer lege rijen (alle cellen zijn leeg); Super zoeken en fuzzy zoeken in veel werkboeken; Willekeurige selectie ...
  • Exacte kopie Meerdere cellen zonder de formuleverwijzing te wijzigen; Maak automatisch verwijzingen naar meerdere bladen; Plaats kogels, Selectievakjes en meer ...
  • Extraheer tekst, Tekst toevoegen, Verwijderen op positie, Ruimte verwijderen; Paging-subtotalen maken en afdrukken; Converteren tussen celinhoud en opmerkingen...
  • Super filter (bewaar en pas filterschema's toe op andere bladen); Geavanceerd sorteren per maand / week / dag, frequentie en meer; Speciaal filter door vet, cursief ...
  • Combineer werkmappen en werkbladen; Tabellen samenvoegen op basis van sleutelkolommen; Gegevens splitsen in meerdere bladen; Batch Converteer xls, xlsx en PDF...
  • Meer dan 300 krachtige functies. Ondersteunt Office / Excel 2007-2019 en 365. Ondersteunt alle talen. Eenvoudig te implementeren in uw onderneming of organisatie. Gratis proefperiode van 30 dagen met volledige functies. 60 dagen geld-terug-garantie.
kte tabblad 201905

Office-tabblad Brengt een interface met tabbladen naar Office en maakt uw werk veel gemakkelijker

  • Schakel bewerken en lezen met tabbladen in Word, Excel, PowerPoint in, Publisher, Access, Visio en Project.
  • Open en maak meerdere documenten in nieuwe tabbladen van hetzelfde venster in plaats van in nieuwe vensters.
  • Verhoogt uw productiviteit met 50% en vermindert elke dag honderden muisklikken!
officetab onderkant
Comments (7)
Nog geen beoordelingen. Beoordeel als eerste!
Deze opmerking is gemaakt door de moderator op de site
Hoe zou je het doen als je het op een andere kolom wilt baseren? Ik heb vergelijkbare gegevens, maar kolom B is een nummer dan notities (zoals je fruit) in kolom I, ik wil alle notities in kolom I combineren totdat er een andere cel in kolom B is die alleen een nummer heeft. Soms staat er een letter onder B of zijn de cellen leeg, daarom moet het worden gecombineerd tot een nummer. Kan het dan eindelijk teruggaan naar waar het de maaidorser begon? IE alle notities voor het eerste nummer staan ​​in kolom j, maar als het volgende nummer 5 rijen lager is dan is dat prima, het gaat gewoon in kolom j maar hetzelfde rijnummer als het nummer wordt gevonden?
Deze opmerking is gemaakt door de moderator op de site
Het geeft aan dat er een syntaxisfout is op regel 3 "Dim xRg As Range" wanneer ik deze module probeer uit te voeren op basis van methode 1, wat moet ik hieraan doen?
Deze opmerking is gemaakt door de moderator op de site
Hallo, JJ, De code werkt goed in mijn werkblad, welke Excel-versie gebruik je? Of je kunt hier een schermafbeelding van je probleem invoegen.
Deze opmerking is gemaakt door de moderator op de site
goed gedaan bro, erg handig
Deze opmerking is gemaakt door de moderator op de site
Hallo,
Alstublieft. Fijn dat het helpt. Heeft u vragen, neem dan gerust contact met ons op. Een fijne dag verder.
Hoogachtend,
Mandy
Deze opmerking is gemaakt door de moderator op de site
Hoi! Waarom werkt de formule niet na het wijzigen van de waarden (bijvoorbeeld watermeloen in plaats van appel)?
Deze opmerking is gemaakt door de moderator op de site
Hallo Cristina

Ons artikel biedt VBA-code, geen formule. Als u de celinhoud wijzigt, moet u de code opnieuw uitvoeren om het juiste resultaat te krijgen.
Dank je!
Er zijn nog geen reacties geplaatst
Laat uw commentaar
Posten als gast
×
Beoordeel dit bericht:
0   Personages
Voorgestelde locaties