Common case
I'll show sample formula for 3 columns, but you may use the same logic for any number of columns.
data:image/s3,"s3://crabby-images/ba225/ba225ed6e67c6a92f834bb44f5273fbc66bf3080" alt="enter image description here"
the formula is
=TRANSPOSE(SPLIT(ARRAYFORMULA(CONCATENATE(TRANSPOSE(FILTER(A2:C,A2:A>0)&"-"))),"-"))
A2:C
is the range with all your columns
A2:A>0
is the condition by column A to choose only proper rows. This may by A2:A<>""
for text column or any condition to limit number of rows.
-
in the formula is any symbol which is not the part of original data. You may use group of symbols, or even special words for the same purpose: =TRANSPOSE(SPLIT(ARRAYFORMULA(CONCATENATE(TRANSPOSE(FILTER(A2:C,A2:A>0)&"devide"))), "devide"))
Case 1.
not continuous columns
If you have data are not in continuous columns.
If so, then you need to change this part of formula FILTER(A2:C,A2:A>0)
into query:
=query(A:AO;"select A,I,Q,Y,AG,AO... where A > 0")
or better this:
=query({A:AO};"select Col1, Col6, Col20, Col22, ... where Col1 > 0")
And the final formula will look like this:
=TRANSPOSE(SPLIT(ARRAYFORMULA(CONCATENATE(TRANSPOSE(query({A:AO};"select Col1, Col6, Col20, Col22, ... where Col1 > 0")&"-"))),"-"))
Case 2.
not continuous columns, data is numbers and text
When you have both numbers and text as input into your data, query
won't work because it can handle only one type of data in one column.
Your simplified case will look like this:
data:image/s3,"s3://crabby-images/595f6/595f608aaf33cff2b34bac7a5cbc1ac94afc1f0d" alt="enter image description here"
The first task is to grab all columns with the name "Ticket number" into one table.
Let's work in the sheet "Report", use filter
function:
=FILTER(Data!1:1001,Data!2:2="Ticket number")
and get the result:
data:image/s3,"s3://crabby-images/7e590/7e5902c0ef5a50ae8099d05d40266d32c61abda1" alt="enter image description here"
Step 2 is implementing the first formula:
=TRANSPOSE(SPLIT(ARRAYFORMULA(CONCATENATE(TRANSPOSE(Report!A3:D&"-"))),"-"))
The other way is to combine columns one by one:
={A2:A5;B2:B5;C2:C5}
If you like this method, you may read more here.