This is best Fabric, Power BI, SQL and AI community event. How do we know? The last event sold out! Save €200 with code FABCMTY200.
Register nowA new Data Days event is coming soon! This time we’re going bigger than ever. Fabric, Power BI, SQL, AI and more. Don't miss out.
I have 2 different Excel tables I'm connecting to in Power Query and have noticed that some of the Column Headers do not match the Column Data. I need to append these 2 tables together, but the Headers need to be identical. I'm looking for a way to shift the column headers or column data in Table 2 so that they align. I listed an example below. My actual data has close to 100 columns so simply renaming the columns & deleteing the empty one will not work.
Solved! Go to Solution.
Hi @Anonymous,
I have a solution for you. It searches for all columns which are empty and removes them. Then shift the names of columns.
I've developed it as a function which will be easier to integrate in your solution.
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WSlTSUUoCYiBKBuIUIE5VitWJVjIEsowgEsZAbALEpkqxsQA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type text) meta [Serialized.Text = true]) in type table [Customer = _t, Product = _t, Qty = _t, Cost = _t, Sell = _t, #" " = _t]),
fnShiftByOneEmptyColumn = (tbl as table) as table =>
let
// get column names of the origin table
ColumnNames = Table.ColumnNames(tbl),
// find columns which don't contain any values
EmptyColumns = List.Select(
ColumnNames,
each List.MatchesAll(Table.Column(tbl, _), each _ = null or _ = "")
),
// remove empty column from the origin table
RemoveEmptyColumn = Table.RemoveColumns(tbl, EmptyColumns),
// rename columns
RenameColumns = Table.RenameColumns(
RemoveEmptyColumn,
List.Zip(
{
// columns of the origin table without empty columns
Table.ColumnNames(RemoveEmptyColumn),
// N-x columns of the origin table
List.RemoveLastN(ColumnNames, List.Count(EmptyColumns))
}
)
)
in
RenameColumns,
Result = fnShiftByOneEmptyColumn(Source)
in
Result
Hi @Anonymous,
I have a solution for you. It searches for all columns which are empty and removes them. Then shift the names of columns.
I've developed it as a function which will be easier to integrate in your solution.
let
Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WSlTSUUoCYiBKBuIUIE5VitWJVjIEsowgEsZAbALEpkqxsQA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type text) meta [Serialized.Text = true]) in type table [Customer = _t, Product = _t, Qty = _t, Cost = _t, Sell = _t, #" " = _t]),
fnShiftByOneEmptyColumn = (tbl as table) as table =>
let
// get column names of the origin table
ColumnNames = Table.ColumnNames(tbl),
// find columns which don't contain any values
EmptyColumns = List.Select(
ColumnNames,
each List.MatchesAll(Table.Column(tbl, _), each _ = null or _ = "")
),
// remove empty column from the origin table
RemoveEmptyColumn = Table.RemoveColumns(tbl, EmptyColumns),
// rename columns
RenameColumns = Table.RenameColumns(
RemoveEmptyColumn,
List.Zip(
{
// columns of the origin table without empty columns
Table.ColumnNames(RemoveEmptyColumn),
// N-x columns of the origin table
List.RemoveLastN(ColumnNames, List.Count(EmptyColumns))
}
)
)
in
RenameColumns,
Result = fnShiftByOneEmptyColumn(Source)
in
Result
Check out the May 2026 Power BI update to learn about new features.
Sign up to receive a private message when registration opens and key events begin.
If you have recently started exploring Fabric, we'd love to hear how it's going. Your feedback can help with product improvements.