?
Solved

Excel VBA:  dynamically insert blank rows after a row with a  call containing a ceritan value

Posted on 2009-04-13
7
Medium Priority
?
753 Views
Last Modified: 2012-05-06
Need to insert a blank row after the row containting "Non Target" (Column C).  The number of times the value "Non Target" cna appear will vary, so it should be dynamic.

Thanks
ee-format-samp.xls
0
Comment
Question by:LeeStink
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
7 Comments
 
LVL 59

Assisted Solution

by:Saurabh Singh Teotia
Saurabh Singh Teotia earned 1000 total points
ID: 24133143
Use this code and it will do what you are looking for...
Saurabh...

Sub insertrows()
    Application.ScreenUpdating = False
 
    Dim i As Long
    i = 5
    Do Until i > Cells(65536, "C").End(xlUp).Row
        If Cells(i, "C").Value = "Non-Target" Then
            Rows(i + 1).Insert
            i = i + 2
        Else
            i = i + 1
        End If
    Loop
 
    MsgBox "Done"
    Application.ScreenUpdating = True
End Sub

Open in new window

0
 
LVL 50

Accepted Solution

by:
Dave Brett earned 1000 total points
ID: 24134040
Using Find (as below) or Filter will offer the quickest code fix
Instructions to run thge macro included in the code below
Regards
Dave

'Press Alt + F11 to open the Visual Basic Editor (VBE)
'From the Menu, choose Insert-Module.
'Paste the code into the right-hand code window.
'Press Alt + F11 to close the VBE
'Go to Tools & Macro ... Macros and double-click InsRow
 
Sub InsRow()
    Dim rng1 As Range, rng2 As Range, cel As Range
    Dim FirstAddress As String
    Dim AppCalc As Long
 
    Application.ScreenUpdating = False
 
    Set cel = Columns("C").Find("Non-Target", , xlValues, xlWhole, xlByRows, , False)
    If Not cel Is Nothing Then
        Set rng2 = cel
        FirstAddress = cel.Address
        Do
            Set cel = Columns("C").FindNext(cel)
            Set rng2 = Union(rng2, cel)
        Loop While FirstAddress <> cel.Address
    End If
 
    If Not rng2 Is Nothing Then rng2.EntireRow.Offset(1, 0).Insert
    Application.ScreenUpdating = True
End Sub

Open in new window

0
 
LVL 1

Expert Comment

by:lethalz
ID: 24340402
Hi LeeStink,

Try this code.
Sub InsertBlankRow()
    i = 6
    With ActiveSheet
        Do While .Cells(i, 3) <> ""
            If .Cells(i, 3) = "Non-Target" Then
                Rows(i + 1 & ":" & i + 1).Insert Shift:=xlDown
                i = i + 1
            End If
            i = i + 1
        Loop
    End With
    Range("A6").Select
End Sub

Open in new window

0
 
LVL 50

Expert Comment

by:Dave Brett
ID: 24408433
Any update here LeeStink?
Cheers
Dave
0
 
LVL 50

Expert Comment

by:Dave Brett
ID: 25875718
Recommend a split between http:#a24134040 and http:#a24133143 to recognise the first solution provided by Saurabh and the different approach by me which will cut run time

Regards

Dave
0

Featured Post

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

When you see single cell contains number and text, and you have to get any date out of it seems like cracking our heads.
Access developers frequently have requirements to interact with Excel (import from or output to) in their applications.  You might be able to accomplish this with the TransferSpreadsheet and OutputTo methods, but in this series of articles I will di…
This Micro Tutorial demonstrate the bugs in Microsoft Excel for Mac with Pivot Charts.
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question