Macro to split, validate, concatenate and transpose

arundharmarajan

New Member
Joined
Jun 12, 2018
Messages
6
Hi,

Another scenario where I am completely stumped and not sure how to solve this.

The scenario is

Column A - has a list of values (one value in one cell)
Column B - Multiple values separated by , or - or even single value
Column C - All possible values that can be present in Column B.

One cell with prefix for column A
One cell with prefix for column B

When I run the macro, the output I require is a table, which is the value in column A and value of column B in each row.

Pretty sure it is confusing, therefore attaching a sample of what I require.

Capture.jpg


Thank you
 

Excel Facts

Create a Pivot Table on a Map
If your data has zip codes, postal codes, or city names, select the data and use Insert, 3D Map. (Found to right of chart icons).
will this do?

Code:
Option Explicit
Dim LastRowNoA As Long
Dim LastRowNoC As Long
Dim ColAloop As Long
Dim ColBloop As Long
Dim ColCloop As Long
Dim ColBString As String
Dim ColBValString As String
Dim ColBLoValString As String
Dim ColBHiValString As String
Dim ColBSearchVal As Integer
Dim RowCount As Integer


Sub FindLastColRow()
LastRowNoA = Worksheets("Sheet1").Cells(Rows.Count, "A").End(xlUp).Row
LastRowNoC = Worksheets("Sheet1").Cells(Rows.Count, "C").End(xlUp).Row
RowCount = 2


For ColAloop = 2 To LastRowNoA
    ColBString = Worksheets("Sheet1").Range("B" & ColAloop).Value
    Do While Len(ColBString) > 0
        ColBValString = Left(ColBString, InStr(1, ColBString, ","))
        If Len(ColBValString) > 0 Then
            If InStr(1, ColBValString, "-") > 0 Then
                ColBLoValString = Left(ColBValString, Len(ColBValString) - InStr(1, ColBValString, "-") - 1)
                ColBHiValString = Right(ColBValString, Len(ColBValString) - InStr(1, ColBValString, "-"))
                ColBHiValString = Left(ColBHiValString, Len(ColBHiValString) - 1)
                For ColCloop = 2 To LastRowNoC
                    If Worksheets("Sheet1").Range("C" & ColCloop).Value >= ColBLoValString And Worksheets("Sheet1").Range("C" & ColCloop).Value <= ColBHiValString Then
                        Worksheets("Sheet1").Range("G" & RowCount).Value = Worksheets("Sheet1").Range("E2").Value & Worksheets("Sheet1").Range("A" & ColAloop).Value
                        Worksheets("Sheet1").Range("H" & RowCount).Value = Worksheets("Sheet1").Range("E5").Value & Worksheets("Sheet1").Range("C" & ColCloop).Value
                        RowCount = RowCount + 1
                    End If
                Next ColCloop
            Else
                ColBSearchVal = Left(ColBValString, Len(ColBValString) - 1)
                For ColCloop = 2 To LastRowNoC
                    If Worksheets("Sheet1").Range("C" & ColCloop).Value = ColBSearchVal Then
                        Worksheets("Sheet1").Range("G" & RowCount).Value = Worksheets("Sheet1").Range("E2").Value & Worksheets("Sheet1").Range("A" & ColAloop).Value
                        Worksheets("Sheet1").Range("H" & RowCount).Value = Worksheets("Sheet1").Range("E5").Value & ColBSearchVal
                        RowCount = RowCount + 1
                    End If
                Next ColCloop
            End If
                
            ColBString = Right(ColBString, Len(ColBString) - Len(ColBValString))
        Else
                For ColCloop = 2 To LastRowNoC
                    If Worksheets("Sheet1").Range("C" & ColCloop).Value = ColBString Then
                        Worksheets("Sheet1").Range("G" & RowCount).Value = Worksheets("Sheet1").Range("E2").Value & Worksheets("Sheet1").Range("A" & ColAloop).Value
                        Worksheets("Sheet1").Range("H" & RowCount).Value = Worksheets("Sheet1").Range("E5").Value & ColBString
                        RowCount = RowCount + 1
                    End If
                Next ColCloop
            ColBString = ""
        End If
    Loop
Next ColAloop
End Sub
 
Upvote 0
Actually this is better as allows for something like 7000,8000-9000 ie with the values separated by a "-" on the end.

Code:
Option Explicit
Dim LastRowNoA As Long
Dim LastRowNoC As Long
Dim ColAloop As Long
Dim ColBloop As Long
Dim ColCloop As Long
Dim ColBString As String
Dim ColBValString As String
Dim ColBLoValString As String
Dim ColBHiValString As String
Dim ColBSearchVal As Integer
Dim RowCount As Integer


Sub FindLastColRow()
LastRowNoA = Worksheets("Sheet1").Cells(Rows.Count, "A").End(xlUp).Row
LastRowNoC = Worksheets("Sheet1").Cells(Rows.Count, "C").End(xlUp).Row
RowCount = 2


For ColAloop = 2 To LastRowNoA
    ColBString = Worksheets("Sheet1").Range("B" & ColAloop).Value
    Do While Len(ColBString) > 0
        ColBValString = Left(ColBString, InStr(1, ColBString, ","))
        If Len(ColBValString) > 0 Then
            If InStr(1, ColBValString, "-") > 0 Then
                ColBLoValString = Left(ColBValString, Len(ColBValString) - InStr(1, ColBValString, "-") - 1)
                ColBHiValString = Right(ColBValString, Len(ColBValString) - InStr(1, ColBValString, "-"))
                ColBHiValString = Left(ColBHiValString, Len(ColBHiValString) - 1)
                For ColCloop = 2 To LastRowNoC
                    If Worksheets("Sheet1").Range("C" & ColCloop).Value >= ColBLoValString And Worksheets("Sheet1").Range("C" & ColCloop).Value <= ColBHiValString Then
                        Worksheets("Sheet1").Range("G" & RowCount).Value = Worksheets("Sheet1").Range("E2").Value & Worksheets("Sheet1").Range("A" & ColAloop).Value
                        Worksheets("Sheet1").Range("H" & RowCount).Value = Worksheets("Sheet1").Range("E5").Value & Worksheets("Sheet1").Range("C" & ColCloop).Value
                        RowCount = RowCount + 1
                    End If
                Next ColCloop
            Else
                ColBSearchVal = Left(ColBValString, Len(ColBValString) - 1)
                For ColCloop = 2 To LastRowNoC
                    If Worksheets("Sheet1").Range("C" & ColCloop).Value = ColBSearchVal Then
                        Worksheets("Sheet1").Range("G" & RowCount).Value = Worksheets("Sheet1").Range("E2").Value & Worksheets("Sheet1").Range("A" & ColAloop).Value
                        Worksheets("Sheet1").Range("H" & RowCount).Value = Worksheets("Sheet1").Range("E5").Value & ColBSearchVal
                        RowCount = RowCount + 1
                    End If
                Next ColCloop
            End If
                
            ColBString = Right(ColBString, Len(ColBString) - Len(ColBValString))
        Else
             If InStr(1, ColBString, "-") > 0 Then
                ColBLoValString = Left(ColBString, InStr(1, ColBString, "-") - 1)
                ColBHiValString = Right(ColBString, Len(ColBString) - InStr(1, ColBString, "-"))
                For ColCloop = 2 To LastRowNoC
                    If Worksheets("Sheet1").Range("C" & ColCloop).Value >= ColBLoValString And Worksheets("Sheet1").Range("C" & ColCloop).Value <= ColBHiValString Then
                        Worksheets("Sheet1").Range("G" & RowCount).Value = Worksheets("Sheet1").Range("E2").Value & Worksheets("Sheet1").Range("A" & ColAloop).Value
                        Worksheets("Sheet1").Range("H" & RowCount).Value = Worksheets("Sheet1").Range("E5").Value & Worksheets("Sheet1").Range("C" & ColCloop).Value
                        RowCount = RowCount + 1
                    End If
                Next ColCloop
            Else
               For ColCloop = 2 To LastRowNoC
                    If Worksheets("Sheet1").Range("C" & ColCloop).Value = ColBString Then
                        Worksheets("Sheet1").Range("G" & RowCount).Value = Worksheets("Sheet1").Range("E2").Value & Worksheets("Sheet1").Range("A" & ColAloop).Value
                        Worksheets("Sheet1").Range("H" & RowCount).Value = Worksheets("Sheet1").Range("E5").Value & ColBString
                        RowCount = RowCount + 1
                    End If
                Next ColCloop
            End If
            ColBString = ""
        End If
    Loop
Next ColAloop
End Sub
 
Upvote 0

Forum statistics

Threads
1,225,750
Messages
6,186,805
Members
453,373
Latest member
Ereha

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