searching for data in columns with the same argument

sjoerd.bosch

New Member
Joined
Feb 9, 2012
Messages
49
Hello.
I am trying to copy/paste data from 2 columns (containing several rows with required data) and transfer the columns to another worksheet in the workbook
over a time span of either 23-24-or 25 hrs
The problem is that I need to use an argument what is not consistent and I have a macro in the workbook what adds a column at the end each time I enter new data.

In the attached I have the source sheet, which is here called "report"and the destination sheet, what is called "for technical report"

In row 6 there are mentioned occasions - which are named in the cell as: noon, eosp, sosp, departure, arrival and some others, which are not important
As said, when I update the daily reports - there is a column added at the end. Thus every day and every occasion a column is added in the sheet "reports'.

What I am looking to do is the following:
Copy / Paste the LAST Noon report and the previous (before the LAST) Noon report to a new column in another sheet, so that I have in the new columns the data in the columns of the last - either 23/24/25 hours (depends if we shift time when travelling East or West). If I have that data in another sheet, i can extract the data what I need on a daily basis.
It doesn't have to contain formulae. Just the data is sufficient
I have tried all sorts, both with macros and the build in formulas, but I am getting nowhere.
Hope you can assist
 

Attachments

  • source sheet.png
    source sheet.png
    32.7 KB · Views: 24
  • destination sheet.png
    destination sheet.png
    36.8 KB · Views: 23
This might do it

VBA Code:
Sub t2()
Dim sh1 As Worksheet, sh2 As Worksheet, fn As Range, adr As String, col1 As Long, col2 As Long
Set sh1 = Sheets("Report")
Set sh2 = Sheets("for technical report")
Set fn = sh1.Rows(6).Find("Noon", Cells(6, Columns.Count), xlValues, xlWhole, , xlPrevious)
    If Not fn Is Nothing Then
    adr = fn.Address
    x = 2
    Do
        sh2.Columns(x) = sh1.Columns(fn.Column).Value
        Set fn = Rows(6).FindPrevious(fn)
        x = x - 1
    Loop While x <> 0
    End If
End Sub
 
Upvote 0

Excel Facts

Did you know Excel offers Filter by Selection?
Add the AutoFilter icon to the Quick Access Toolbar. Select a cell containing Apple, click AutoFilter, and you will get all rows with Apple
Almost. That code copies the every first noon report in the columns way back in 2018 when inserted into the original reporting workbook (all the records are added to the end of any existing records).
Therefore we have many noon messages from before and many to come. The above code copies the very first. I only need the last and the one before last.
 
Upvote 0
I am not getting that kind of result. On my test set up it only brought over the last two Noon entries on row 6.

Here is the "Report" Sheet I use.

TestBase.xlsm
ABCDEFGHIJKLMN
1xxxxxxxxxxxxxx
2xxxxxxxxxxxxxx
3xxxxxxxxxxxxxx
4xxxxxxxxxxxxxx
5xxxxxxxxxxxxxx
6fjeingNoonfkjeoigjkepNoonddkjwpomndoiepdklwNoondkjesddklep;fdkgfNoondoieps
7dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
8dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
9dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
10dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
11dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
12dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
13dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
14dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
15dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
16dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
17dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
18dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
19dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
20dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
21dfgasdfgwerfbdeeerswgeretepreviousxsdderfsesffsLastgehe
Report


And Here is the other sheet with the results.

TestBase.xlsm
AB
1xx
2xx
3xx
4xx
5xx
6NoonNoon
7previousLast
8previousLast
9previousLast
10previousLast
11previousLast
12previousLast
13previousLast
14previousLast
15previousLast
16previousLast
17previousLast
18previousLast
19previousLast
20previousLast
21previousLast
for technical report
 
Upvote 0
it just occurred to me that you might have archived Columns of data on the same worksheet somewhere to the right of your current report data, in which case this line
VBA Code:
Set fn = sh1.Rows(6).Find("Noon", Cells(6, Columns.Count), xlValues, xlWhole, , xlPrevious)
Would definitely find your old data because it goes all the way to the end of row 6 and works back to the left to find the first 'Noon' entry. So if you can describe to me where the archived data begins, including any other data that may be entered on row 6 to the right of the current data, I can fix the code so it only evaluates current data.
 
Upvote 0
Hi. this is how it looks on my end.
Funny thing is - I just tried the code on a clean sheet and it works
When I insert it in a new module in my workbook, it copies the very 1st column and the last one.
The 1st column should actually also be there [preferably], but main thing is the 2 Noon reports, so that I can use it for a final message sheet.
Is there a way to send you my complete workbook?
 

Attachments

  • Capt 2 For daily tech.png
    Capt 2 For daily tech.png
    47.4 KB · Views: 7
  • Voy.Report sheet.png
    Voy.Report sheet.png
    101.5 KB · Views: 7
Upvote 0
Let's try this rivised code. It attempts to use the current date as a marker for finding the last Noon entry. If your dates in row 4 are date data types formatted as 5.9.2020 then it should work.
However if the dates are just a manual input and not date data type, it will fail.

VBA Code:
Sub t4()
Dim sh1 As Worksheet, sh2 As Worksheet, fn As Range, x As Long, col As Long
Set sh1 = Sheets("Report")
Set sh2 = Sheets("for technical report")
Set fn = sh1.Rows(4).Find(Date, sh1.Cells(4, Columns.Count), xlValues, xlPart, , xlPrevious)
    If Not fn Is Nothing Then
        col = fn.Offset(, 1).Column
    Else
        MsgBox "Date Not Found, Correction Needed." & vbLf & "Procedure will Terminate!", vbCritical, "NO DATE"
        Exit Sub
    End If
Set fn = Nothing
Set fn = sh1.Rows(6).Find("Noon", sh1.Cells(6, col), xlValues, xlWhole, , xlPrevious)
    If Not fn Is Nothing Then
    x = 2
        Do
            sh2.Columns(x) = sh1.Columns(fn.Column).Value
            Set fn = sh1.Rows(6).FindPrevious(fn)
            x = x - 1
        Loop While x <> 0
    End If
End Sub
 
Upvote 0
I don't accept direct email attachments. I only respond to issues on the forum.
If there are blank columns after the columns you are showing in you screen shots, then this code should work. The only problem I am having with the code is finding a starting point to search for the word "Noon". I did not expect that there would be columns of old data off to the right of your current data. That was not specified in the OP. If the Date method won't work then this would be the only other way to get there without doing a lot of looping, which would take longer to run.

VBA Code:
Sub t5()
Dim sh1 As Worksheet, sh2 As Worksheet, fn As Range, x As Long, col As Long
Set sh1 = Sheets("Report")
Set sh2 = Sheets("for technical report")
col = sh1.Cells(6, 1).End(xlToRight).Column + 1
Set fn = sh1.Rows(6).Find("Noon", sh1.Cells(6, col), xlValues, xlWhole, , xlPrevious)
    If Not fn Is Nothing Then
    x = 2
        Do
            sh2.Columns(x) = sh1.Columns(fn.Column).Value
            Set fn = sh1.Rows(6).FindPrevious(fn)
            x = x - 1
        Loop While x <> 0
    End If
End Sub
 
Upvote 0
I also tweaked the one using the Date to find a starting point, and it seems to now be working.

VBA Code:
Sub t4()
Dim sh1 As Worksheet, sh2 As Worksheet, fn As Range, x As Long, col As Long
Set sh1 = Sheets("Report")
Set sh2 = Sheets("for technical report")
Set fn = sh1.Rows(4).Find(Format(Date, "d.m.yyyy"), sh1.Cells(4, Columns.Count), xlValues, xlPart, , xlPrevious)
    If Not fn Is Nothing Then
        col = fn.Offset(, 1).Column
    Else
        MsgBox "Date Not Found, Correction Needed." & vbLf & "Procedure will Terminate!", vbCritical, "NO DATE"
        Exit Sub
    End If
Set fn = Nothing
Set fn = sh1.Rows(6).Find("Noon", sh1.Cells(6, col), xlValues, xlWhole, , xlPrevious)
    If Not fn Is Nothing Then
    x = 2
        Do
            sh2.Columns(x) = sh1.Columns(fn.Column).Value
            Set fn = sh1.Rows(6).FindPrevious(fn)
            x = x - 1
        Loop While x <> 0
    End If
End Sub
 
Upvote 0
Hi. < I don't accept direct email attachments. I only respond to issues on the forum > Oh okay. understand. Sorry that I asked. It is sometimes a little diffivult to explain.
But that code actually works perfect. It copies and pastes the columns I want into the 1st two columns of the daily sheet.
One more question - What if I want to keep some original data in the 1st column of the daily sheet and the noon reports in the 2nd and 3rd column?
 
Upvote 0

Forum statistics

Threads
1,225,626
Messages
6,186,089
Members
453,336
Latest member
Excelnoob223

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