VBA to Insert Rows??

CERipkenJr

New Member
Joined
May 22, 2017
Messages
9
Hi there.

I have used the following code (copied from the Internet) with success - it inserts rows into my spreadsheet based on a number from another cell - perfect:

[TABLE="width: 448"]
<tbody>[TR]
[TD="colspan: 6"]Private Sub Worksheet_Change(ByVal Target As Range)[/TD]
[TD][/TD]
[/TR]
[TR]
[TD="colspan: 5"] If Target.AddressLocal = "$P$5" Then[/TD]
[TD][/TD]
[TD][/TD]
[/TR]
[TR]
[TD="colspan: 3"] Dim i As Integer[/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[/TR]
[TR]
[TD="colspan: 4"] For i = 1 To Target.Value[/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[/TR]
[TR]
[TD="colspan: 5"] Range("2:2").EntireRow.Insert[/TD]
[TD][/TD]
[TD][/TD]
[/TR]
[TR]
[TD="colspan: 2"] Next i[/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[/TR]
[TR]
[TD="colspan: 2"] End If[/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[/TR]
[TR]
[TD]End Sub

How would I go about altering this code to add text to the row(s) created? (i.e. I need all inserted rows to say "Option Rent" in a particular cell of the added row(s).

Thanks a million.[/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[/TR]
[TR]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[TD][/TD]
[/TR]
</tbody>[/TABLE]
 
Last edited:

Excel Facts

How to fill five years of quarters?
Type 1Q-2023 in a cell. Grab the fill handle and drag down or right. After 4Q-2023, Excel will jump to 1Q-2024. Dash can be any character.
Perhaps something like this, change C:C to whatever column you want to add 'Option Rent' in.
Code:
Private Sub Worksheet_Change(ByVal Target As Range)
Dim I As Long

    If Target.AddressLocal = "$P$5" Then
        
        Range("2:2").Resize(Target.Value).Insert
        Intersect(Range("C:C"), Range("2:2").Resize(Target.Value)).Value = "Option Rent"
        
    End If
    
End Sub
 
Upvote 0
Thanks so much. Follow up questions:

1. How can I eliminate the run-time error '1004': Application-defined or object-defined error when the value in cell P5 is deleted?

2. This won't run on a protected sheet - any way around that?
 
Upvote 0
1 Try this.
Code:
Private Sub Worksheet_Change(ByVal Target As Range)
Dim I As Long

    If Target.AddressLocal = "$P$5" Then
        
        If Not IsEmpty(Target) Then
            Range("2:2").Resize(Target.Value).Insert
            Intersect(Range("C:C"), Range("2:2").Resize(Target.Value)).Value = "Option Rent"
        End If
        
    End If
    
End Sub

2 Perhaps something like this
Code:
Private Sub Worksheet_Change(ByVal Target As Range)
Dim I As Long

    If Target.AddressLocal = "$P$5" Then
        
        If Not IsEmpty(Target) Then
            Me.Unprotect
            Range("2:2").Resize(Target.Value).Insert
            Intersect(Range("C:C"), Range("2:2").Resize(Target.Value)).Value = "Option Rent"
            Me.Protect
        End If
        
    End If
    
End Sub
 
Upvote 0
1 Try this.
Code:
Private Sub Worksheet_Change(ByVal Target As Range)
Dim I As Long

    If Target.AddressLocal = "$P$5" Then
        
        If Not IsEmpty(Target) Then
            Range("2:2").Resize(Target.Value).Insert
            Intersect(Range("C:C"), Range("2:2").Resize(Target.Value)).Value = "Option Rent"
        End If
        
    End If
    
End Sub

2 Perhaps something like this
Code:
Private Sub Worksheet_Change(ByVal Target As Range)
Dim I As Long

    If Target.AddressLocal = "$P$5" Then
        
        If Not IsEmpty(Target) Then
            Me.Unprotect
            Range("2:2").Resize(Target.Value).Insert
            Intersect(Range("C:C"), Range("2:2").Resize(Target.Value)).Value = "Option Rent"
            Me.Protect
        End If
        
    End If
    
End Sub


I love you. Thanks a million!
 
Upvote 0
1 Try this.
Code:
Private Sub Worksheet_Change(ByVal Target As Range)
Dim I As Long

    If Target.AddressLocal = "$P$5" Then
        
        If Not IsEmpty(Target) Then
            Range("2:2").Resize(Target.Value).Insert
            Intersect(Range("C:C"), Range("2:2").Resize(Target.Value)).Value = "Option Rent"
        End If
        
    End If
    
End Sub

2 Perhaps something like this
Code:
Private Sub Worksheet_Change(ByVal Target As Range)
Dim I As Long

    If Target.AddressLocal = "$P$5" Then
        
        If Not IsEmpty(Target) Then
            Me.Unprotect
            Range("2:2").Resize(Target.Value).Insert
            Intersect(Range("C:C"), Range("2:2").Resize(Target.Value)).Value = "Option Rent"
            Me.Protect
        End If
        
    End If
    
End Sub


Ok, last question (I promise). (For now).

What about if, when a user deletes the data in P5, it deletes the previously inserted rows?

Also - how "advanced"-level are these questions that I'm asking? I'm VERY novice with VBA (obviously).
 
Upvote 0

Forum statistics

Threads
1,225,761
Messages
6,186,893
Members
453,383
Latest member
SSXP

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