VBA Insert Row - fails sometimes

Rijnsent

Well-known Member
Joined
Oct 17, 2005
Messages
1,460
Office Version
  1. 365
Platform
  1. Windows
I have a bit of code that has been working fine for years, but now suddenly get feedback from some users that my error catching shows them "Insert method of range class failed". The simplified version of my code is the following:
VBA Code:
Sub AddLine()

On Error GoTo ErrCatch
Set Sht = Worksheets("SHEET_A")
Sht.Unprotect Password:="PWD"
Rw = ActiveCell.Row 
Set FirstCl = Sht.Cells(Rw, 1)
FirstCl.Rows("1:1").EntireRow.Copy
FirstCl.Rows("1:1").EntireRow.Insert Shift:=xlDown

Exit Sub
ErrCatch:
       Debug.Print Err.source, Err.Description
End Sub
As I wrote, it seems like it works fine for almost all users, but recently some bumped into this issue. It seems like the .Insert line sometimes fails, but I can't see what might cause it, as it does always work on the 2 test-laptops where me and my colleague work on. Does anyone have a pointer?
 

Excel Facts

What is the fastest way to copy a formula?
If A2:A50000 contain data. Enter a formula in B2. Select B2. Double-click the Fill Handle and Excel will shoot the formula down to B50000.
Does it give you a debug option?
If so, which line of code does it highlight when you click it?

On the users where it is failing, if they click CTRL+END, what cell does Excel go to?
If it goes to the very last possible row in Excel, then it thinks they are already using all the rows. So it wouldn't allow you to insert any new ones.
This happens sometimes if people format or populate an entire column on their sheet (so Excel thinks all rows are being used).
 
Upvote 0
There is a recent (end of May release) bug that seems to be affecting quite a few people with inserting/deleting rows, so it may be related. Are you all on the same build?
 
Upvote 0
Solution
Hi @Joe4,
well, my VBA-code is locked, so if my user bumps into that warning I can't see where the code stopped (the debug is unavailable), but I can see the warning. My hunch is that it's the .insert line causing the problems because of the error message "Insert method of range class failed" (and there is no other line in my code inserting something). The weird thing: the same Excel file (with this code) does give that error on one PC, but won't give the error on another. The ActiveCell.Row gets checked for being <2000, so this macro won't be called from the last row of the sheet.

The sheet itself is locked and only about 2k rows are in use, but formatting might indeed run to the bottom of the sheet. But your idea of Excel thinking that all rows are used does sound plausible, I've seen that before. Is there a VBA-way to check and/or correct that?

The users are on different builds of Excel/Office/Windows, so @RoryA 's idea that it has to do with the end of May release sounds like the most logical suspect. @RoryA Is there a way to follow these updates and the new issues they cause? (It's not the first time this year that we bump into some update of Excel that bugs out some parts of our code.)

Cheers,
Koen
 
Upvote 0
Not specifically - I only know about this because of posts I've seen in forums.
 
Upvote 0

Forum statistics

Threads
1,224,929
Messages
6,181,812
Members
453,067
Latest member
mdiz777

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