Power Query: Dynamic Removals
4 March 2020
Welcome to our Power Query blog. This week, I look at how to remove columns without referencing column names.
John, my reliable imaginary salesperson, has been filling in data again. This time, he has added a few extra columns to his data.
data:image/s3,"s3://crabby-images/70413/70413ceb4fd4e90e60489afba386db0591a9c632" alt=""
John has been keeping track of how the expenses have been paid for, but I don’t need this information. I will extract the data into Power Query. To do this, I use ‘From Table’ on the ‘Get & Transform’ section of the ‘Data’ tab.
data:image/s3,"s3://crabby-images/33145/3314566c52b484f29bf202ddc5bed6ebbe911221" alt=""
My data has headers, so I accept the suggested options in the dialog.
data:image/s3,"s3://crabby-images/2a1c6/2a1c6680dfab2983d29fa49e36080a33943b9bb0" alt=""
I select the columns I want to remove, keeping CTRL pressed, and right-click to remove columns.
data:image/s3,"s3://crabby-images/fe359/fe3590f752c6bae70de5ddbc45f146488cbadcc7" alt=""
I want to check the M code generated for this step.
data:image/s3,"s3://crabby-images/41241/4124100ca257e6535aedea28826dea6f6b0b7b7c" alt=""
The M code generated is
= Table.RemoveColumns(#"Changed Type",{"Card", "Cash", "Mike"})
The problem with this, is that John will come up with other column names next time. I need a more dynamic way of choosing which columns to remove. To do this, I go back to my initial ‘Source’ step and delete the other steps. I will add a new step using the fx button next to the Formula bar.
data:image/s3,"s3://crabby-images/2d7c0/2d7c02633e3c4be6103fb1c595726bc9d6735cff" alt=""
The step I am going to add will create a list of my column names.
data:image/s3,"s3://crabby-images/9249a/9249aacebca28c3a5223b7c7f0cccd86e88fe08f" alt=""
The M code I am using is:
= Table.ColumnNames(Source)
I also used Table.ColumnNames in Power Query: Name or Number, when I was renaming columns using their position instead of their column names.
data:image/s3,"s3://crabby-images/3dae7/3dae74c2e3146e607f3ff1f1739e156f33cb52d9" alt=""
I have a list of my column names. I want to convert this to a table using the ‘Convert to Table’ option on the ‘List Tools, Transform’ tab.
data:image/s3,"s3://crabby-images/446e9/446e9a4101a4aa7f080a4fc01a40af8616c74855" alt=""
I accept the defaults and create my table.
data:image/s3,"s3://crabby-images/e31bb/e31bb1c62d44f7eebab9e1529bc4682e2a520ea2" alt=""
I want to filter my table so that I only have the columns I want to remove.
data:image/s3,"s3://crabby-images/f7b70/f7b709a71d0a3fc25433eed1123e7d7c7f4b941c" alt=""
I click OK to leave the columns I want to remove.
data:image/s3,"s3://crabby-images/7d764/7d7649bb84b584973e49575ed180c24e71b13982" alt=""
I need to reference this table when I remove columns. I add a new step that will take the source and remove the columns in this table.
data:image/s3,"s3://crabby-images/04b9e/04b9ecf0cece3a4e07b37b684a1e35d441eba417" alt=""
The M code I have used is:
= Table.RemoveColumns(Source,#"Filtered Rows"[Column1])
data:image/s3,"s3://crabby-images/a2512/a2512a2712d6e4ab9f44ac37d357b83aec32100e" alt=""
This removes the other columns without referencing their names. I can check that this will work if John adds other columns. I ‘Close & Load’ my data first, and then add another expense to John’s table:
data:image/s3,"s3://crabby-images/08e44/08e449827c8e74b1cd0361164edaa553fc6f084e" alt=""
I have added another column, Cheque, to pay for a hotel bill. I refresh the query to see the results.
data:image/s3,"s3://crabby-images/1b201/1b2011d04444d746d97c6c02ab76b4b9a2730d7d" alt=""
The hotel expense has been added, but new column Cheque is not shown. It works!
Come back next time for more ways to use Power Query!