ExcelBanter

ExcelBanter (https://www.excelbanter.com/)
-   Excel Programming (https://www.excelbanter.com/excel-programming/)
-   -   Use macro to check a range of cells within a row and copy wanted data to new sheet (https://www.excelbanter.com/excel-programming/311887-use-macro-check-range-cells-within-row-copy-wanted-data-new-sheet.html)

busspeed[_2_]

Use macro to check a range of cells within a row and copy wanted data to new sheet
 

This worked perfectly!!!!!

Thank you so much!

You have just saved me tons of work. Awesome. I promise to study th
code so that instead of asking questions in the future, I can hopefull
contribute.


Bernie Deitrick Wrote:
bus,

MACRO

You can use a macro - the macro below will extract all the data for a
particular class code and copy it to a new worksheet.

MANUAL

The manual method that depends on one additional column of formulas
Firts,
though, you will need a single cell for the class code that you wan
to
extract. Let's use A1 for our example.

Then use a column of formulas - in, let's say, column I, which I'l
assume
to be blank: Enter this if cell I2:

=NOT(ISERROR(MATCH($A$1,A2:H2,FALSE)))

and copy that down to match your table.

Then use Data | Filter... Autofilter, and select the TRUE values o
column
I. Then select your entire data table, use Edit | Go To... Special
Visible
cells, then do your copy and paste to the new sheet.

HTH,
Bernie
MS Excel MVP

Sub FindClassCodeValues()
Dim c As Range ' The cell found with what you want
Dim d As Range ' All the cells found with what you want
Dim myFindString As String
Dim firstAddress As String
Dim mySht As Worksheet

myFindString = InputBox("Enter the class code", , "Hello")
With Cells
Set c = .Find(myFindString, LookIn:=xlValues, lookAt:=xlWhole)

If Not c Is Nothing Then
Set d = c
firstAddress = c.Address
Else:
MsgBox "Not Found"
End
End If

Set c = .FindNext(c)
If Not c Is Nothing And c.Address < firstAddress Then
Do
Set d = Union(d, c)
Set c = .FindNext(c)
Loop While Not c Is Nothing And c.Address < firstAddress
End If
End With
'Then all the rows of the cells that have been found

Set mySht = Worksheets.Add
mySht.Name = "Class " & myFindString
d.EntireRow.Copy mySht.Range("A1")

End Sub



"busspeed" wrote in message
...

I have a problem and am not very familiar with VBA.
What I need to do is check a row of data one at a time (there ar

about
3000 total rows) looking for a class number (the class numbers ar

in
different columns within the row). When I find that class numbe

within
the row I need to *copy* the row to another sheet. I am simply tryin

to
grab all of the students in certain classes and paste them o

another
sheet.

Here is a sample of the data:
Adams gadams21 041184 84022 84260
Adams hadams4 111591 83772
Adams dadams25 041645 84020 84282
Adams madams3 082981 83969
Adams sadams9 120369 81838 84025 86460

The first column is last name (yes, I have changed the data...non

of
it is sensitive).
The second column is user name.
3rd column is birthday.
Remaining columns are classes they are in (can vary; some can be i

5
classes, some in 1).

Any help would be greatly appreciated.

Thanks,

busspeed


--
busspeed


------------------------------------------------------------------------
busspeed's Profile:

http://www.excelforum.com/member.php...o&userid=14829
View this thread

http://www.excelforum.com/showthread...hreadid=264630


--
busspee
-----------------------------------------------------------------------
busspeed's Profile: http://www.excelforum.com/member.php...fo&userid=1482
View this thread: http://www.excelforum.com/showthread.php?threadid=26463



All times are GMT +1. The time now is 09:06 PM.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
ExcelBanter.com