Hoe automatisch lege cellen boven / links samenvoegen in Excel?
In dit artikel ga ik het hebben over het automatisch samenvoegen van lege cellen boven of links, zoals onderstaand screenshot. Eigenlijk is er geen ingebouwd hulpprogramma dat deze taak aankan, maar de macrocodes wel.
Voeg bovenstaande spaties samen | ||
![]() |
![]() |
![]() |
Voeg lege plekken links samen | ||
![]() |
![]() |
![]() |
Voeg bovenstaande lege cellen samen op basis van een kolom
Voeg lege cellen hierboven samen (werkt alleen voor enkele kolom)
Voeg bovenstaande lege cellen samen op basis van een kolom
Stel dat er een gegevensbereik is in drie kolommen, en nu wilt u de bovenstaande gegevens samenvoegen op basis van kolom C.
1. druk op Alt+F11 keys om het Microsoft Visual Basic voor toepassingen venster en klik Invoegen > Module. Zie screenshot:
2. Plak vervolgens onderstaande code in het lege script. Zie screenshot:
VBA: voeg hierboven blanco samen op basis van de volgende kolom
Sub MergeCells()
'UpdatebyExtendoffice2017025
Dim xRg As Range
Dim xCell As Range
Dim xAddress As String
On Error Resume Next
xAddress = Application.ActiveWindow.RangeSelection.Address
Set xRg = Application.InputBox("Select a range:", "KuTools For Excel", xAddress, , , , , 8)
If xRg Is Nothing Then Exit Sub
For Each xCell In xRg
If xCell.Value = "" Then
Range(xCell, xCell.Offset(-1, 0)).Merge
End If
Next
End Sub
3. druk op F5 toets om de code uit te voeren, en dan verschijnt er een dialoogvenster om u eraan te herinneren een bereik te selecteren om te werken. Zie screenshot:
4. klikken OK, dan zijn de lege cellen hierboven samengevoegd. Zie screenshot:
Voeg lege cellen hierboven samen (werkt alleen voor enkele kolom)
Hier is een macrocode die de lege cellen hierboven in de opgegeven kolom kan samenvoegen.
1. druk op Alt + F11 toetsen om het Microsoft Visual Basic voor toepassingen venster en klik Invoegen > Module. Zie screenshot:
2. Plak onderstaande code in het script. Zie screenshot:
VBA: voeg bovenstaande lege cellen samen
Sub mergeblankswithabove()
'UpdatebyExtendoffice20171025
Dim I As Long
Dim xRow As Long
Dim xRg As Range
Dim xCell As Range
Dim xAddress As String
On Error Resume Next
xAddress = Application.ActiveWindow.RangeSelection.Address
Set xRg = Application.InputBox("Select a range (single column):", "KuTools For Excel", xAddress, , , , , 8)
If xRg Is Nothing Then Exit Sub
If xRg.Columns.Count > 1 Then
MsgBox "Only work for single column", , "KuTools For Excel"
Exit Sub
End If
xRow = xRg.Rows.Count
Set xRg = xRg(xRow)
For I = xRow To 1 Step -1
Set xCell = xRg.Offset(I - xRow, 0)
Debug.Print xCell.Address
If xCell.Value = "" Then Range(xCell, xCell.Offset(-1, 0)).Merge
Next
End Sub
3. druk op F5 toets om de code uit te voeren, en er verschijnt een dialoogvenster waarin u een kolombereik kunt selecteren. Zie screenshot:
4. Klik op OK. En de lege cellen in de selectie zijn hierboven samengevoegd.
![]() |
![]() |
![]() |
Voeg lege cellen links samen
Als u lege cellen links wilt samenvoegen, kan de volgende code u een plezier doen.
1. druk op Alt + F11 toetsen om het Microsoft Visual Basic voor het venster Toepassingen en klik op Invoegen > Module. Zie screenshot:
2. Plak vervolgens onderstaande code in het lege script. Zie screenshot:
VBA: voeg lege plekken links samen
Sub mergeblankswithleft()
'UpdatebyExtendoffice20171025
Dim xRg As Range
Dim xCell As Range
Dim xAddress As String
On Error Resume Next
xAddress = Application.ActiveWindow.RangeSelection.Address
Set xRg = Application.InputBox("Select a range:", "KuTools For Excel", xAddress, , , , , 8)
If xRg Is Nothing Then Exit Sub
For Each xCell In xRg
If xCell.Value = "" Then Range(xCell, xCell.Offset(0, -1)).Merge
Next
End Sub
3. druk op F5 toets om de code uit te voeren, en er verschijnt een dialoogvenster waarin u een bereik kunt selecteren. Zie screenshot:
4. klikken OK. De lege cellen zijn links samengevoegd.
Voeg lege plekken links samen | ||
![]() |
![]() |
![]() |
Voeg dezelfde cellen samen of ontkoppel de cel
|
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-2021 en 365. Ondersteunt alle talen. Eenvoudig te implementeren in uw onderneming of organisatie. Volledige functies Gratis proefperiode van 30 dagen. 60 dagen geld-terug-garantie.

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 honderden muisklikken voor u elke dag!
