If / Loop / Merge

deadlyjack

New Member
Joined
Aug 21, 2021
Messages
23
Office Version
  1. 365
  2. 2019
Platform
  1. Windows
I've got a little task where I need to merge 2 rows together IF the value is greater than 11.
I got the first code to work, but this is only for a specific row...
What I need to generate is a dynamic Loop throughout, x = 3 To 33.
In this case I3 is greater than 11, so if this is the case, then I need to jump I4 and continue my loop on I5.
There's probably an easier code for this that won't crash My excel-file, so please, if you have an answer that may reduce useage of RAM, show me an alternative ?

In other words:
VBA Code:
If Produktionshall.Cells(x, "I") <= 11 Then
    Range("A4:P4").Select
    Selection.Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
    Range( _
        "B3:B4,C3:C4,D3:D4,E3:E4,F3:F4,G3:G4,H3:H4,I3:I4,J3:J4,K3:K4,L3:L4,M3:M4,O3:O4,P3:P4" _
        ).Select
    Range("P3").Activate
    With Selection
        .HorizontalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
    Selection.Merge
    With Selection
        .HorizontalAlignment = xlCenter
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
    End With
    Range("A3").Select
    Selection.Copy
    Range("A4").Select
    ActiveSheet.Paste
    Exit Function
    End If

VBA Code:
Sub DrumCount()
myVar = CheckDrums
End Sub

By the way, I'd also need to repeat this process IF I3 greater than 22. Then I'd need to merge 4 rows together in the same way, instead of two rows.
 

Excel Facts

Copy a format multiple times
Select a formatted range. Double-click the Format Painter (left side of Home tab). You can paste formatting multiple times. Esc to stop
You want all cell values at merged Cell or only first value?
Because merge only hold first cell value at merged range.
 
Upvote 0
1. Greater than Or less Than. Your macro tell Less Than?

2. You want only merge at column I or merge all columns from A to P?
For example if I3 < 11 Them
Merge
A3:A4
B3:B4
....
I3:I4
....

Or Only

I3:I4
 
Last edited:
Upvote 0
Try this for Less Than Condition and all column merging from A to P:
VBA Code:
Sub MergingCR()
Dim i As Long, j As Long
Application.ScreenUpdating = False
For i = 33 To 3 Step -1
    Select Case Cells(i, "I")
    Case ""
    GoTo NextCase
    Case Is <= 11
        Range("A" & i + 1 & ":P" & i + 1).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        For j = 1 To 16
        Range(Cells(i, j), Cells(i + 1, j)).MergeCells = True
        Next j
        GoTo NextCase
     Case Is <= 22
        Range("A" & i + 1 & ":P" & i + 1).Resize(3).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        For j = 1 To 16
        Range(Cells(i, j), Cells(i + 3, j)).MergeCells = True
        Next j
    End Select
NextCase:
Next i
Application.ScreenUpdating = True
End Sub
 
Upvote 0
Thank you Maabadi for a quick response. Yes! This was exactly what I was looking for, but had to change the, Case Is <= 11, to, Case Is >=11. If the value is more than 11, then merge two rows together (1+1), or more than 22, then merge 4 rows together (1+3).

Also I cannot merge Column A & N, because these require to be accessed through our PivotTable with special letters... A-column could copypaste the cell above and paste it into the new row merged together with it.
 
Upvote 0
I restructured the code a bit, but it's more to my satisfaction now.
Now I just need to figure out how to give both A & N Bottom Borders, to each specific row.
Not sure what to change if I'd like to leave column A & N out of this equation.... Could you help me with that?

VBA Code:
Function CheckDrums()
Dim i As Long, j As Long
Application.ScreenUpdating = False
For i = 19 To 3 Step -1
    Select Case Cells(i, "I")
    Case ""
    GoTo NextCase
     Case Is >= 22
        Range("A" & i + 1 & ":P" & i + 1).Resize(3).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        For j = 1 To 16
        Range(Cells(i, j), Cells(i + 3, j)).MergeCells = True
     Next j

    GoTo NextCase
     Case Is >= 11
        Range("A" & i + 1 & ":P" & i + 1).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        For j = 1 To 16
        Range(Cells(i, j), Cells(i + 1, j)).MergeCells = True
     Next j
    End Select
NextCase:
Next i
Application.ScreenUpdating = True
End Function

Sub DrumCount()
myVar = CheckDrums
End Sub
 
Upvote 0
If I understand Correct, you want this:
VBA Code:
Function CheckDrums()
Dim i As Long, j As Long
Application.ScreenUpdating = False
For i = 19 To 3 Step -1
    Select Case Cells(i, "I")
    Case ""
    GoTo NextCase
     Case Is >= 22
        Range("A" & i + 1 & ":P" & i + 1).Resize(3).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        For j = 1 To 16
        If j = 1 Or j = 14 Then
        Cells(i + 3, j).Borders(xlEdgeBottom).Weight = xlThin
        Else
        Range(Cells(i, j), Cells(i + 3, j)).MergeCells = True
        End If
     Next j

    GoTo NextCase
     Case Is >= 11
        Range("A" & i + 1 & ":P" & i + 1).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        For j = 1 To 16
        If j = 1 Or j = 14 Then
        Cells(i + 1, j).Borders(xlEdgeBottom).Weight = xlThin
        Else
        Range(Cells(i, j), Cells(i + 1, j)).MergeCells = True
        End If
     Next j
    End Select
NextCase:
Next i
Application.ScreenUpdating = True
End Function

Sub DrumCount()
myVar = CheckDrums
End Sub
 
Upvote 0
This works perfectly! Thanks!

Let's say, for the sake of somebody elses safety, that I would like to implement a safezone, where if someone would accidentally press the button two times, the code will not repeat itself on rows that has already been merged... Is this possible to activate somehow?

What I am making is a list that will constantly be filled with new projects. Therefore, all I can think of right now is to add an additional button that will reverse what we just did, then after adding new projects, I could click the Merge-button once again... a merge & unmerge-button by switching .MergeCells = True to .MergeCells = False

But it would've been nicer to have a command that implements this right from the start :unsure:

I really appretiate all the help you've provided so far maababi!
 
Upvote 0
if someone would accidentally press the button two times, the code will not repeat
Add This after Dim Line
VBA Code:
If Range("I" & Range("I3:I30").Find(Application.WorksheetFunction.Max(Range("I3:I30"))).Row).MergeCells = True Then Exit Function
 
Upvote 0
I get Run-time error '91':
Object variable or with block variable not set
.

VBA Code:
Function CheckDrums()
Dim i As Long, j As Long
If Range("I" & Range("I3:I33").Find(Application.WorksheetFunction.Max(Range("I3:I33"))).Row).MergeCells = True Then
Exit Function
Application.ScreenUpdating = False
For i = 33 To 3 Step -1
    Select Case Cells(i, "I")
    Case ""
    GoTo NextCase
     Case Is >= 22
        Range("A" & i + 1 & ":P" & i + 1).Resize(3).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        For j = 1 To 16
        If j = 1 Or j = 14 Then
        Cells(i + 3, j).Borders(xlEdgeBottom).Weight = xlThin
        Else
        Range(Cells(i, j), Cells(i + 3, j)).MergeCells = True
        End If
     Next j

    GoTo NextCase
     Case Is >= 11
        Range("A" & i + 1 & ":P" & i + 1).Insert Shift:=xlDown, CopyOrigin:=xlFormatFromLeftOrAbove
        For j = 1 To 16
        If j = 1 Or j = 14 Then
        Cells(i + 1, j).Borders(xlEdgeBottom).Weight = xlThin
        Else
        Range(Cells(i, j), Cells(i + 1, j)).MergeCells = True
        End If
     Next j
    End Select
NextCase:
Next i
Application.ScreenUpdating = True
End If
End Function

Sub DrumCount()
myVar = CheckDrums
End Sub
 
Last edited:
Upvote 0

Forum statistics

Threads
1,224,755
Messages
6,180,771
Members
452,996
Latest member
nelsonsix66

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top