Revision: 12091
Initial Code
Initial URL
Initial Description
Initial Title
Initial Tags
Initial Language
at March 2, 2009 02:18 by pckujawa
Initial Code
Function FindNth(rTable As Range, Val1 As Variant, ResultCol As Integer) As String ''''''''''''''''''''''''''''''''''''''' 'Written by OzGrid Business Applications 'www.ozgrid.com ' Finds ALL occurences in the first Column of a table. ' Merges results ''''''''''''''''''''''''''''''''''''''' 'Used like; '=FindNth($A$1:$B$37,"ALFA5010",2) Dim lLoop As Long Dim rFound As Range Dim strResults As String With rTable.Columns(1) Set rFound = .Cells(, 1) For lLoop = 1 To WorksheetFunction.CountIf(.Cells, Val1) Set rFound = .Cells.Find(Val1, rFound, xlValues, xlWhole, xlNext, xlRows, False) If strResults <> vbNullString Then strResults = strResults & rFound(1, ResultCol) ' Had "& Chr(10) &" to add CR/LF, but I removed it Else strResults = rFound(1, ResultCol) End If Next lLoop End With FindNth = RTrim(strResults) End Function
Initial URL
http://www.ozgrid.com/forum/showthread.php?t=114520
Initial Description
Say you've got data combined in such a way that there is a repeated row header, but all the data is in different rows. If you were to consolidate all the rows down to one, only taking valid values (discarding blanks), you'd have one header row with all the data. This function does that for you. Ex: `StudentID,TestScore1, TestScore2,TestScore3 1,100,, 1,,98, 1,,,97` Becomes: `StudentID,TestScore1, TestScore2,TestScore3 1,100,98,97`
Initial Title
Look up all occurences and merge results (consolidate)
Initial Tags
excel
Initial Language
Visual Basic