Advertisement

05.04.2008 at 04:26PM PDT, ID: 23375407
[x]
Attachment Details

Copy range from one worksheet to another workbook worksheet based on value in a cell

Asked by llawrenceg in Microsoft Excel Spreadsheet Software, Spreadsheet Software

Tags: Microsoft, Excel, 2003, corporaate environment

I need some VBA code to copy worksheet rows of data from columns V to Z  to another workbook to two different worksheets depending upon  the criteria in column H. The values in the rows on columns V to Z are formulas. the actual values are to be copied.

While the value in column H is "Y" copy the rows from Column V to Z to workbook GTABT2.xls worksheet NCE range A4
While the value in column H is "N" copy the rows from Column V to Z  to workbook
GTABPT2.xls worksheet NHCE range A4
If the value in column H is neither Y nor N tehn do nothingStart Free Trial
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:
31:
32:
33:
34:
35:
36:
37:
38:
39:
40:
41:
42:
43:
44:
45:
46:
47:
Sub Row_Transfer()
Dim WshTgt As Worksheet, WshSrce As Worksheet
Set WshTgt = Workbooks("GTABPT2.xls") _
    .Worksheets("HCE")
Set WshSrce = Workbooks("fit_assessment_allocation_template2.xls") _
    .Worksheets("scenario 1 -9and3")
Set WshTgt2 = Workbooks("GTABPT2.xls") _
    .Worksheets("NHCE")
        Dim LRow As Integer, lngcol As Long, Lngcolumn As Long
        Dim LCell As String
        Dim LColorCells As String
        'Start at row 5
With WshSrce
        LRow = 5
Application.ScreenUpdating = False
        'Update row colors for the first 20  rows
        While LRow < 20
            LCell = "H" & LRow
            'Cells to copy are column V to Z not empty rows
            LColorCells = "V" & LRow & ":" & "Z" & LRow
 
            Select Case Left(Range(LCell).Value, 8)
 
                'copy HCEs to HCE sheet
                Case "Y"
                      WshTgt.Cells(4, 1) = WshSrce.Range(LColorCells)
                    
 
                'copy NHCEs to NHCE Sheet
                Case "N"
                    Rows(LRow & ":" & LRow).Select
                    WshTgt2.Cells(4, 1) = WshSrce.Range(LColorCells)
                     
 
                'do not copy other cells
                Case Else
                    Rows(LRow & ":" & LRow).Select
                    Range(LColorCells).Interior.ColorIndex = xlNone
                    
            End Select
 
            LRow = LRow + 1
        Wend
End With
        Range("A1").Select
Application.ScreenUpdating = True
    End Sub
Attachments:
 
Source file to copy from
 
[+][-]05.04.2008 at 04:54PM PDT, ID: 21497454

View this solution now by starting your 7-day free trial. Setting up your free trial is quick, easy, and secure. We will return you to this solution, unlocked, when you're done.

 

About this solution

Zones: Microsoft Excel Spreadsheet Software, Spreadsheet Software
Tags: Microsoft, Excel, 2003, corporaate environment
Sign Up Now!
Solution Provided By: byundt
Participating Experts: 1
Solution Grade: A
 
 
[+][-]05.04.2008 at 05:05PM PDT, ID: 21497479

Often, when Experts are collaborating with members who have asked questions, they will request additional information about the problem. Askers respond with an author comment like this one.

Start your 7-day free trial to view this Author Comment or ask the Experts your question.

 
 
Loading Advertisement...
20080716-EE-VQP-32 / EE_QW_2_20070628