Combine 3 non-contiguous columns into one removing blanks - array help?

Emerlin

Board Regular
Joined
Jan 8, 2007
Messages
117
Office Version
  1. 2016
Platform
  1. Windows
Hi,

I have data in columns B2:B9, D2:D9 and F2:F9. Some of those cells have blanks.

I would like to combine them into one column in starting in J2 and ignore the blanks.

I know this is an array formula, and can get one column to work with this:
=IFERROR(INDEX($B$2:$B$9,SMALL(IF($B$2:$B$9<>"",ROW($B$2:$B$9)-ROW(B$2)+1),ROWS(J$2:J2))),"")

How can I add the other columns to the list...? I have tried multiple things with no success.

Thanks in advance for any all help.
 
Last edited:
Thank you for your efforts - I am using stand alone, desktop version of Excel 2016.
OK, so you don't have the TEXTJOIN function I believe. You can still use an auto-updating standard worksheet formula.

Excel Workbook
BCDEFGHIJ
1
2redorangered
3blueredblue
4yellowblackyellow
5greenwhiteblack
6blackyellowbluered
7green
8yellow
9orange
10black
11white
12blue
13
List data
 
Upvote 0

Excel Facts

Format cells as time
Select range and press Ctrl+Shift+2 to format cells as time. (Shift 2 is the @ sign).
@ Peter Ah... the above looks most useful. I will implement and report back.

Thanks!
 
Last edited:
Upvote 0
Thank you Rick this mostly works. I am trying to reverse engineer this so i can perhaps use it elsewhere -

Evaluate("ROW(2:" & LastRow & ")"), Split("2 4 6"))

Is that the line that specifies which row to start in? and 2,4,6 are the columns to start?

My problem is that there is other data below Row 10 in columns B,D,and F that this is picking up as well. Any way to have it look at only range B2:B10?
Here is my code revised so that you can modify the values highlighted in red for use elsewhere...
Code:
[table="width: 500"]
[tr]
	[td]Sub CombineColumnsBandDandF()
  Dim R As Long, C As Long, X As Long, StartRow As Long, LastRow As Long, ColCount As Long
  Dim Cols As String, Arr As Variant, Result As Variant
  StartRow = [B][COLOR="#FF0000"][SIZE=3]2[/SIZE][/COLOR][/B]
  LastRow = [B][COLOR="#FF0000"][SIZE=3]10[/SIZE][/COLOR][/B]
  Cols = [B][COLOR="#FF0000"][SIZE=3]"2 4 6"[/SIZE][/COLOR][/B] [B][COLOR="#008000"] 'Column numbers separated by spaces[/COLOR][/B]
  ColCount = 1 + UBound(Split(Cols))
  Arr = Application.Index(Cells, Evaluate("ROW(" & StartRow & ":" & LastRow & ")"), Split(Cols))
  ReDim Result(1 To ColCount * LastRow, 1 To 1)
  For C = 1 To ColCount
    For R = 1 To UBound(Arr)
      If Len(Arr(R, C)) Then
        X = X + 1
        Result(X, 1) = Arr(R, C)
      End If
    Next
  Next
  Range("[B][COLOR="#FF0000"][SIZE=3]J2[/SIZE][/COLOR][/B]").Resize(UBound(Result)) = Result
End Sub[/td]
[/tr]
[/table]
 
Upvote 0
@ Peter and @ Rick

Both solutions worked very well. I think both have their place in this. The VBA was new to me so enjoy getting a chance to work with it.

I am very thankful to both you. You help was invaluable. You both taught me a new things about excel today which I will use moving forward. I hope it may help others.

Best Regards
 
Upvote 0
@ Peter and @ Rick

I am very thankful to both you. You help was invaluable. You both taught me a new things about excel today which I will use moving forward.
You are very welcome. :)


Given the sort of parameters like Rick's red values near the start of his code, this could then be done without any looping and in a single line as follows, though I'm not suggesting you do that. ;)
I think I would stick with the formulas.

Code:
Sub CombineColumnsWithoutBlanks()
  Const StartRow As Long = 2
  Const LastRow As Long = 10
  Const Cols As String = "2 4 6"
  
  Range("J2").Resize((1 + UBound(Split(Cols))) * (LastRow - StartRow + 1)).Value = Application.Transpose(Split(Replace(Join(Filter(Split(Join( _
    Application.Transpose(Application.Index(Application.Index(Cells, Evaluate("row(" & StartRow & ":" & LastRow & ")"), Split(Cols)), _
    Evaluate("if(row(1:" & (1 + UBound(Split(Cols))) * (LastRow - StartRow + 1) & "),mod(row(1:" & (1 + UBound(Split(Cols))) * (LastRow - StartRow + 1) & _
              ")-row(1:1),rows(1:" & LastRow - StartRow + 1 & "))+1)"), _
    Evaluate("if(row(1:" & (1 + UBound(Split(Cols))) * (LastRow - StartRow + 1) & "),int((row(1:" & (1 + UBound(Split(Cols))) * (LastRow - StartRow + 1) & _
              ")-row(1:1))/rows(1:" & LastRow - StartRow + 1 & "))+1)"))), _
              "|#|"), "#"), "||", False)), "| |", "|") & String((1 + UBound(Split(Cols))) * (LastRow - StartRow + 1), "|"), "|"))
End Sub

The introduction of some variables could make this code line more efficient (and easier to read) if required.
 
Last edited:
Upvote 0

Forum statistics

Threads
1,225,149
Messages
6,183,187
Members
453,151
Latest member
Lizamaison

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